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ПРЕДИСЛОВИЕ 

Доступность информации, объем и скорость ее обработки 
становятся решающими факторами развития производительных 
сил государства, науки, культуры, общественных институтов и т.д. 
Переработка информации вплоть до конца 70-х годов осущест¬ 
влялась в основном на больших и средних ЭВМ. В них создава¬ 
лись большие банки данных, а ввод и вывод информации 
осуществлялся операторами с удаленных терминалов. По 
существу, весь процесс переработки информации выполнялся 
профессионалами, и конечный пользователь чаще всего не имел 
к ней быстрого доступа. Разработка и бурное распространение 
с конца 70-х годов мини- и микрокомпьютеров, а также 
персональных компьютеров (ПК) не только приблизили конечно¬ 
го, часто профессионально не подготовленного пользователя к 
процессу переработки информации, но и позволили активно в 
него включиться. 

Большую роль в этом сыграли специально разработанные для 
ПК программные средства - текстовые редакторы, системы 
управления базами данных (СУБД), системы автоматизации 
проектных работ и т.д. Их отличительная особенность от прог¬ 
раммных продуктов для больших и средних ЭВМ заключается в 
создании более удобного - "дружественного” интерфейса пользо¬ 
вателя. Соединение ПК с большими и средними ЭВМ предо¬ 
ставляет конечному пользователю их информационные ресурсы 
и оставляет все преимущества ПК. 

Среди СУБД для ПК наиболее распространенным в мире 
является семейство СІВА5Е фирмы АзЬіоп-Таіе. Такая популярность 
объясняется отчасти исторически, так как эта СУБД лоявиласс 
одной из первых на рынке программных продуктов данного про¬ 
филя. Но не в меньшей степени этому способствовала удачность 
заложенных основ конструкции СУБД и командного языка. Пре¬ 
дыдущая версия этого семейства СІВА5Е 111+ широко использу¬ 
ется В СССР. По ней издано несколько книг, например Д.Г.Бе- 
рещанский "Практическое программирование на СІВА5Е", Р.Крамм 
"Системы управления базами данных сіВАБЕ II и сіВАБЕ III для 
персональных компьютеров". В новой версии сіВАБЕ IV концеп¬ 
ция СУБД и командный язык получили значительное развитие, 
позволившее устранить недостатки предыдущей версии, а также 
существенно обогатить палитру средств обработки данных и улуч¬ 
шить интерфейс пользователя. В данной книге выполнен анализ 
структуры и компонентов СУБД и командного языка версии 1.0 
сіВАБЕ IV и на многочисленных примерах показаны их функции 
и возможности. 

Главы 1, 3 и 4 написаны Б.А. Романовым, главы 2 и 5 - 
совместно' Б.А. Романовым и А.С. Кушниренко. 

В книге упоминается учебная дискета, сведения о которой 
читатель найдет в рекламном объявлении на 2-й стр. обложки. 
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Глава 1 

ОБЩИЕ СВЕДЕНИЯ О ПАКЕТЕ 4ВА$Е IV 

1.1. СРАВНИТЕЛЬНЫЕ ХАРАКТЕРИСТИКИ СУБД 
РЕЛЯЦИОННОГО ТИПА 

Информация в ЭВМ записывается в закодированном виде на 
различных носителях (чаще всего используются магнитные 
поверхности - диски, ленты и др.). В настоящее время наиболее 
распространена система кодирования, в которой каждый символ 
информации представляется в виде двоичного числа из 8 разря¬ 
дов. Единицей количества информациии служит бит (один 
двоичный разряд) или байт (8 бит). 

Хранение информации осуществляется в виде записей, 
составленных из блоков данных различного типа (чисел, 
символов и т.д.), относящихся к одному информационному 
объекту. Примером записи служит совокупность данных в 
библиографической карточке. Информация определенного 
профиля, отделяемая в записи специальными разделителями, 
называется полем записи (например, в библиографической 
карточке полями являются название книги, фамилия автора, год 
издания и т.д.). Совокупность записей составляет файл данных, 
а набор файлов образует базу данных (БД). Операции по 
обеспечению хранения и обработки данных в файлах 
выполняются с помощью операционной системы (ОС) ПК. Для 
более удобного обращения к файлам на дисках в развитой ОС 
создается хранилище файлов - файловая система, в которой 
файлы объединяются в группы по их целевому назначению. 
Каждой группе присваивается имя - директорий этой группы. 
Совокупность директориев рассматривается в ОС как специаль¬ 
ный файл, которому также присваивается имя - директорий 
более высокого уровня. Так образуется древовидная иерархи¬ 
ческая структура директориев. 

Директорий самого высокого уровня называется корневым, 
а на самом нижнем уровне директориев находятся файлы 
пользователей. Для обращения к файлу задается маршрут по 
директориям, который включает имя файла и перечень директо¬ 
риев (о'< корневого до ведущих к искомому файлу) по следу¬ 
ющей форме: С:\МАІЫ\ВА$А\РВОРІіЛОе1аіІ, где С: - имя диска; 
первая наклонная черта после имени диска означает корневой 
директорий, а остальные служат разделителями между именами 
директориев; МАІИ, ВАЗА и РВОРІІ» - директории нижестоящих 
уровней; ОеіаіІ - имя файла. Заметим, что имена дисков, файлов 
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и директориев можно записывать как строчными, так и пропис¬ 
ными буквами. 

Для того чтобы более эффективно использовать несколько 
ПК, выполняющих обработку общей информации, создаются 
локальные вычислительные сети ПК (ЛВС). Организация ЛВС 
позволяет использовать общие ресурсы ПК, передаваемые в 
состав ЛВС, периферийные устройства - дисковые устройства 
большой емкости, принтеры, плоттеры, сканеры и т.д., а также 
программы и данные. В ЛВС, по крайней мере, один ПК 
большой производительности выполняет роль так называемого 
файлового сервера, управляющего передачей данных и разделе¬ 
нием периферийных устройств. Остальные ПК называются 
рабочими станциями или узлами ЛВС. 

Типы рабочих станций определяются функциями ЛВС. 
Например, в состав ЛВС могут входить маломощные ПК с 
небольшой оперативной памятью и невысоким быстродействием, 
без гибких и жестких дисков, предназначенные для ввода данных 
с клавиатуры и записи ее на периферийный диск большой 
емкости, в котором размещается банк данных. Другие ПК в 
составе ЛВС могут иметь различные конфигурации внешних 
устройств, в которых варьируется количество гибких и жестких 
дисков, принтеров и т.д. Например, могут быть конфигурации с 
одним или двумя гибкими дисками без жесткого или с жестким 
диском, с принтером или без него и т.д. в зависимости от 
выполняемых функций. Разделенные прикладные программы 
загружаются в рабочую станцию из файлового сервера и 
выполняются в ней, а разделенные данные передаются из 
файлового сервера по сети в рабочую станцию и в ней обраба¬ 
тываются. 

Операционная система служит для общей организации 
процесса работы ПК и обеспечения простейших операций по 
обработке данных. Для того чтобы выполнить более сложные 
операции по манипулированию данными на ПК (поиск и отбор 
данных, обеспечение удобного ввода и обновления данных, 
формирование и печать выходных документов и т.д.) разрабаты¬ 
ваются различные системы управления базами данных (СУБД). 

При решении многих информационных задач в настоящее 
время широко используются СУБД реляционного типа. В этих 
СУБД реализуется реляционная модель данных - представление 
их в табличном виде. Строка такой таблицы эквивалентна записи 
файла БД, а колонка - полю записи. Доступ к элементу данных 
осуществляется посредством связи требуемой строки (записи) 
с требуемой колонкой (полем). Многие СУБД реляционного 
типа позволяют языковыми средствами поддерживать и другие 
модели данных, например, иерархическую. В иерархической 
модели данные связываются по уровням. Данные высшего уровня 
называются родительскими, а связанные с ними данные 
следующего уровня - сыновними. Иерархическая модель 
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формируется за счет связи таблиц по общему полю, отдельной 
записи и т.п. 

Можно выделить три основных типа связей записей: 
рдна-одна запись; одна-несколько (несколько-одна) записей; 
несколько-несколько записей. 

Примером связи записей одна-одна служит запись, включа¬ 
ющая фамилию, имя и отчество и запись биографии одного 
человека. Связь типа одна-несколько записей - это, например, 
записи, включающие данные о рейсах, выполненных водителем 
за определенный период времени. Связь типа несколько-нес¬ 
колько записей можно представить в виде перекрестных ссылок, 
которые имеются в книгах. 


Фамилия Имя Отчество^--I Биография 


Водитель 


Москва-Горький 


—С 


Москва - Рязань 


Москве 1 . - Тамбов 


Книга 1 


Книга 2 



і 

Книга 2 


Книга 1 ! 



I 

Книга 3 


Книга 5 



і 

_1 _ 

| Книга 4 


Книга 6 


К числу СУБД реляционного типа, предназначенных для ПК, 
относятся: семейство сІВАЗЕ (сІВАЗЕ II, III, ІІІ+ и IV), СІіррег, 
РохЬа$е, К:ВА5Е, Рагасіох и др. В этих СУБД записи и соответ¬ 
ственно поля имеют обычно фиксированную длину (чаще всего 
длина такой записи достигает 4000...5000 байт). Исключение 
составляют поля типа Мето, используемые, например, в СУБД 
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семейства сІВАЗЕ. Число полей в перечисленных СУБД варьиру¬ 
ется от 128 до 1024. 

Длина поля зависит от типа поля и может составлять от 255 
до 4000 байт для текстовых полей, до 20 байт для числовых 
полей и имеет фиксированные значения для полей типа даты (8 
байт) и логических полей (1 байт). Поле типа Мето служит для 
хранения больших массивов текстовой информации и хранится в 
отдельном файле БД, но воспринимается как поле в составе ос¬ 
новного файла БД. Это поле имеет плавающую длину, определя¬ 
емую объемом введенной текстовой информации, и может 
достигать 32767 байт. 

Большинство СУБД реляционного типа для ПК позволяют 
создавать файлы с числом записей до 1 млрд, и объемом до 2 
тыс. Мбайт. Обычно ограничением на число и объем записей в 
первую очередь выступает емкость внешней памяти ПК. В 
настоящее время в широкой практике используются твердые 
диски (с магнитной запоминающей поверхностью) с емкостью 
памяти до 100...300 Мбайт. 

В состав многих СУБД, предназначенных для работы на ПК, 
входят три основных компонента: командный язык, интерпрети¬ 
рующая система или компилятор для преобразования команд к 
выполнимому виду и средства взаимодействия пользователя с 
СУБД (интерфейс пользователя). 

Командный язык служит для выполнения и обеспечения 
требуемых операций с данными - позволяет создавать структу¬ 
ры файлов БД и манипулировать данными, создавать прикладные 
программы, экранные формы ввода и вывода информации и т.д. 
Структура и возможности языка в значительной степени опреде¬ 
ляют облик конкретной СУБД, ее возможности. В состав 
командного языка ПК также обычно входят специальные команды 
по установке параметров и состояний системы (ЗЕТ-команды), 
а также функции, предназначенные для различных видов 
обработки данных и выполнения вспомогательных действий. 

В СУБД команды можно выполнять по одной, после набора 
с клавиатуры, или группами команд в автоматическом режиме, 
предварительно записанных в специальный (программный) .файл. 
Команды языка СУБД записываются в текстовой форме, близкой 
к обычному языку. Для того чтобы ПК могла выполнить такую 
команду, ее надо преобразовать в вид исполнимых машинных 
команд. 

Существует два принципиально различных способа такого 
преобразования. В первом способе используется интерпретирую¬ 
щая система, которая преобразует поочередно команды в 
исполнимый вид перед их непосредственным выполнением. Во 
втором способе сначала вся исходная программа преобразуется 
(компилируется) в программу из исполнимых машинных команд 
и затем эта программа выполняется. 
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Первый способ выполнения команд СУБД имеет то преиму¬ 
щество, что исходная программа занимает сравнительно немного 
места в памяти. Кроме того, этот способ позволяет выполнять 
команды по одной в режиме ввода с клавиатуры или в режиме, 
управляемом с помощью меню. Однако выполнение исходной 
программы посредством интерпретации команд происходит 
достаточно медленно. Второй способ в отличие от первого 
позволяет выполнять программу значительно быстрее, но 
программа, составленная из машинных команд, занимает 
значительно больше оперативной памяти. 

Объем откомпилированных программ по сравнению с их 
записью на исходном командном языке СУБД может увеличиться 
в 7-10 раз. Для уменьшения занимаемой оперативной памяти 
применяются различные способы, например, создаются оверлей¬ 
ные (перекрываемые) структуры программ и используется 
динамическое распределение элементов программы в памяти. 
При организации оверлейной структуры в оперативной памяти 
находится только выполняемая в текущий момент часть програм¬ 
мы (модуль), а другие модули хранятся на диске и вызываются 
в память по мере потребности в их выполнении. 

При динамическом распределении памяти используется 
похожая идея, но реализуется она в более автоматизированном 
исполнении и применительно не к модулю в целом, а к его 
элементам - переменным, массивам и т.д. Однако сравнивая 
скорости выполнения программ двумя способами, следует также 
иметь в виду, что при использовании интерпретирующей системы 
в оперативной памяти ПК одновременно находится и программа 
этой системы, что снижает выигрыш в памяти. В настоящее 
время наметилась тенденция к отходу от применения интерпре¬ 
тирующих систем в чистом виде. Стремление повысить скорость 
выполнения команд в режиме интерпретации привело к 
необходимости специальной предварительной обработки (пре¬ 
образования) исходной программы. 

В результате такого преобразования, называемого псевдоком¬ 
пиляцией, создается объектный модуль, подготовленный для 
ускоренного выполнения команд в режиме интерпретации. В 
последнее время достигнуты большие успехи в разработке 
псевдокомпиляторов - программ, обеспечивающих этот процесс. 
В печати по ПК отмечается, что скоростные параметры некото¬ 
рых СУБД с псевдокомпиляторами (например, РохЬа$е 2.10) 
обеспечивают даже более высокую скорость выполнения команд, 
чем компиляторы (СІіррег). Таким образом, видна тенденция к 
сближению двух основных способов выполнения команд СУБД. 
Однако различие между ними все же остается и выбор конкрет¬ 
ной СУБД определяется целями ее использования. 

Системы управления базами данных с компиляторами 
программ в основном ориентированы на программистов, созда¬ 
ющих сложные прикладные системы, а СУБД с интерпретиру- 
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ющими системами предназначены для широкого круТ"гГ 
пользователей, как овладевающих основами программиста ни я, 
так и активно повышающих свою программистскую квалифика¬ 
цию, вплоть до уровня профессиональных программистов. 

Взаимодействие пользователя с СУБД, в которой использу¬ 
ется интерпретирующая система, обычно может осуществляться 
в режиме, управляемом с помощью меню, и режиме, ввода 
команд с клавиатуры. Первый режим дает возможность пользова¬ 
телям работать с пакетом СУБД, не зная командного языка. 
Содержание выполняемых команд записывается в позициях меню 
на естественном языке. Пользователь выбирает нужную позицию 
меню и нажимает клавишу исполнения команды. Обычно в меню 
включают достаточно широкий круг команд языка СУБД, позволя¬ 
ющий выполнять многие операции по обработке данных, однако 
далеко не все. При использовании режима ввода команд с 
клавиатуры требуется знать их синтаксис и способы применения. 
Этот режим применяется уже более подготовленными пользова¬ 
телями. Признаком данного режима СУБД служит какой-либо 
знак (например, точка в левом нижнем углу экрана ПК), 
который служит приглашением для набора команды. В дальней¬ 
шем для простоты будем называть этот режим просто команд¬ 
ным. 

Развитие интерфейса пользователя с СУБД в настоящее 
время идет в направлении включения в режим, управляемый 
меню все большего количества средств, расширяющих 
возможности неподготовленных пользователей по управлению 
данными. Например, последние версии таких СУБД, как СІВА5Е, 
КВА5Е й др., содержат генераторы прикладных программ, 
позволяющие пользователям без знания командного языка 
создавать программы средней степени сложности. Эти средства 
могут применяться как неподготовленными пользователями, так 
и профессиональными программистами для уменьшения трудозат¬ 
рат при разработке прикладных программ. 

Структура и содержание компонентов СУБД определяет ее 
назначение и круг потенциальных пользователей. Пользователей 
ПК в зависимости от уровня подготовки и диапазона решаемых 
ими задач можно разделить на три группы: 

пользователи, которым для решения своих задач требуется 
сравнительно небольшой набор функций пакета СУБД (создание 
файлов данных, ввод и обновление данных, вывод на печать 
несложных выходных документов и т.д.); 

пользователи, которым необходимо знать многие функции 
пакета СУБД, в том числе и элементы командного языка, но не 
требуется создавать сложные программы; 

программисты, в задачи которых входит разработка сложных 
прикладных программ по управлению и обработке файлов БД. 

Для пользователей первой группы необходимо включать в 
состав СУБД режим, управляемый с помощью меню. Пользова- 
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телцівторой группы могут осваивать командный режим. Третья 
группѣ пользователей ждет от СУБД достаточно полного набора 
удобных средств для разработки сложных программ. 

Последние версии семейства СУБД сІВАЗЕ - сІВАЗЕ 111+ и 
IV отвечают требованиям всех перечисленных групп 
пользователей. В их состав входит весьма развитый командный 
язык, называемый также сІВАЗЕ, который фактически стал 
стандартом командного языка СУБД реляционного типа для ПК; 
интерпретирующая система (с псевдокомпилятором в сІВАЗЕ IV); 
интерфейс пользователя, включающий режим, управляемый с 
помощью меню, и командный режим. Одним из фактов 
признания языка сІВАЗЕ в качестве стандарта можно считать то, 
что он взят в качестве основы для разработки СУБД, в которых 
используются компиляторы, например, СУБД СІіррег и Оиіскзііѵег. 

Структура файлов БД семейства сІВАЗЕ включает текстовые 
поля длиной до 254 байт, числовые поля (до 20 байт), поля 
типа даты, логические поля и поля типа Мето. Командный язык 
СУБД СІіррег создан на основе языка сІВАЗЕ 111+ и включает 
большинство его команд. Не включены в основном полноэкран¬ 
ные команды, например, команда реализации режима управления 
с помощью меню А$$і$і, команда вызова справочной информации 
Неір и др. Кроме того, в СУБД СІіррег ряд команд сІВАЗЕ III + 
выполняется несколько иначе и введены новые команды. 
Введенные новые команды в языке СІіррег можно рассматривать 
как развитие языка сІВАЗЕ 111+ в некоторых направлениях, 
например, в направлении средств разработки меню прикладных 
программ, которые слабо представлены в сІВАЗЕ III+ . 

Однако различие систем команд в целом небольшое, что 
позволяет программы, созданные в СУБД сІВАЗЕ с учетом 
небольших отличий в системе команд, компилировать с помощью 
СУБД СІіррег в исполнимые файлы и затем выполнять их, не 
используя СУБД сІВАЗЕ. 

Структура создаваемых СУБД СІіррег файлов БД аналогична 
структуре файлов БД сІВАЗЕ. В то же время возможности СУБД 
СІіррег по сравнению с сІВАЗЕ 111+ в плане организации файлов 
БД имеют некоторые преимущества. В файлах СУБД СІіррег 
может быть до 1024 поля (128 в сІВАЗЕ 111 + ), можно вводить 
до 64 000 переменных (256 в сІВАЗЕ 111 + ), устанавливать связь 
между 9 файлами БД (между" двумя файлами в сІВАЗЕ III+ ). 
Предусмотрена также возможность создания оверлейных структур 
разрабатываемых программ. 

Пакет СУБД РохЬазе ориентирован на пользователей второй 
и третьей групп. В ранних версиях этого пакета отсутствовал 
режим работы, управляемый меню. Однако СУБД, как и другие 
программные продукты для ПК, стремительно развиваются. 
Приблизительно через 1... 1,5 года появляются новые версии или 
значительно обновленные пакеты. При этом происходит взаимное 
влияние различных концепций, быстро реализуются новые идеи. 
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Так, в версии РохЬа$е + 2.10 (1988 г.) используется интерфейс 

пользователя, управляемый с помощью меню (Сепігаі), хотя и 
весьма ограниченный по своим возможностям. В то же время в 
этой версии расширены средства автоматизированной разработки 
элементов прикладных программ - введен язык создания макетов 
(язык генерации генераторов программных файлов) для 
разработки унифицированных прикладных программ типа 
экранных форм ввода и вывода, отчетов и т.д., что говорит о 
сохранении пакетом своей специализации, предназначенной в 
основном для разработки прикладных программ. Командный язык 
этой СУБД, как и СУБД СІіррег, в основном тот же, что и в 
сІВАЗЕ 111 +, а структура файлов БД полностью совпадает с 
СУБД сІВАЗЕ. В отличие от СУБД СІіррег для выполнения команд 
в РохЬа$е используется интерпретирующая система, что привязы¬ 
вает разработанные прикладные программы к пакету. Однако для 
выполнения программ предусмотрено использование отдельно 
загружаемого интерпретатора, что уменьшает потребность в 
оперативной памяти. Перед выполнением программ осуществля¬ 
ется их псевдокомпиляция с целью создания объектного 
исполняемого модуля. При этом разработчики добились такого 
совершенства подготовки объектного модуля, что в настоящее 
время пакет РохЬа$е является наиболее "быстрым" среди СУБД 
этого класса. 

По своей структуре и реализации версии СУБД К:ВА5Е, 
выпущенные до 1988 г., были больше ориентированы на 

пользователей первой и второй групп. Последняя версия этой 
СУБД может использоваться и профессиональными программиста¬ 
ми, так как для ее командного языка разработан компилятор. В 
качестве командного языка используется язык типа 301. (струк¬ 
турированный язык запросов, специально разработанный для 
выполнения сложных запросов на поиск и отбор данных из БД 
небольшим набором команд). 

В состав СУБД также входит интерпретирующая система и 
реализован режим управления файлами БД с помощью меню. В 
состав одной БД может входить до 80 файлов (таблиц), вклю¬ 
чающих различные типы полей: числовые (целые, действи¬ 
тельные числа, удвоенной точности), поля даты и времени, 
текстовые поля двух типов: іехі (длиной до 1500 байт) и поіе 
(длиной до 4092 байт). Общее число полей может достигать 
800. Режим, управляемый с помощью меню, позволяет создавать 
и изменять структуры файлов БД, разрабатывать экранные 
формы ввода и вывода информации, формировать запросы на 
выборку информации из нескольких файлов БД, генерировать 
отчеты. В последнюю версию входит также генератор приклад¬ 
ных программ. К положительным сторонам этого пакета относит¬ 
ся возможность размещения в одной записи довольно больших 
объемов текстовой информации, значительное количество полей 
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в файлах БД, весьма перспективный язык манипулирования 
данными 5СИ.. 

По своим возможностям СУБД Рагасіох является одним из 
наиболее развитых пакетов СУБД реляционного типа и предназ¬ 
начен также в основном для пользователей первой и второй 
группы для решения широкого круга задач, хотя может исполь¬ 
зоваться и опытными программистами с целью создания сложных 
программ обработки данных. В состав СУБД Рагасіох входит 
командный язык, интерпретирующая система и интерфейс 
пользователя, управляемый меню. В структуру БД могут 
включаться текстовые поля длиной до 254 байт, числовые поля, 
поля типа даты и логические поля фиксированной длины. 

Командный язык в основном имеет ту же логику выполнения 
операций, что и языки семейства сІВАЗЕ, но представлен своим 
набором команд. Специфика командного языка Рагасіох 
заключается в том, что он интегрирован со своей интерпретиру¬ 
ющей системой, которая может находиться в нескольких 
режимах работы, в результате чего некоторые команды 
выполняются по-разному в зависимости от режима работы 
интерпретирующей системы. Поэтому для командного языка 
СУБД Рагасіох, пока нет компилятора, что ограничивает область 
применения этого пакета. 

Отличительной особенностью данной СУБД является мощный 
интерфейс пользователя, управляемый меню. В состав этого 
интерфейса входят средства создания экранных форм ввода и 
вывода информации, удобная система формирования запросов на 
поиск, отбор и вывод данных из нескольких взаимосвязанных 
файлов БД, генератор отчетов и большой набор вспомогательных 
средств. Особенно развитыми являются средства формирования 
запросов на поиск и отбор данных с помощью специальных 
шаблонов (так называемые запросы по образцу), которые 
упрощают эту работу для неподготовленных пользователей. 
Способ формирования запросов по образцу является в настоящее 
время стандартом интерфейса пользователя в части поиска 
данных и распространяется в другие СУБД. 

Режим работы СУБД Рагасіох, управляемый меню, позволяет 
формировать и выполнять довольно сложные последовательности 
операций (сценарии), включая условия ветвления процесса по 
созданию файлов БД, отбору требуемых данных и вывод их на 
экран и принтер. При выполнении сценариев автоматически 
определяется наиболее оптимальный способ поиска и отбора 
данных, что можно рассматривать как реализацию некоторых 
элементов искуственного интеллекта Несмотря на то, что 
команды в пакете выполняются интерпретирующей системой, 
отмечается весьма высокая скорость обработки больших файлов 
БД. В табл. 1.1 даны сравнительные характеристики СУБД 
реляционного типа. 
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Таблица 1.1. Характеристики некоторых СУБД реляционного 

типа 


Характеристика 

Рагасіох 

2.0 

сіВАЗЕ 

IV 

1.0 

сіВАЗЕ 

111^ 

Я'.Ьаве 
Гог 00$ 
2.11 

РохЬазе 

2.10 

Ввод и гюовеока данных 
Командный режим и режим, 

Есть 

Есть 

Есть 

Есть 

Есть 

управляемый меню 
Количество экранных форм 

15 

ОПП 

ОПП 

ОПП 

ОПП 

на один файл БД 

Количество строк в одной 

320 

32000 

250 

115 

99 

экранной форме 

Проверка данных с помощью 

Есть 

Есть 

В 

Есть 

В 

специальной таблицы 
Проверка диапазона 

*• 

» 

Есть 

іі 

Есть 

вводимых данных 

Проверка дублирования 

•• 

99 

Нет 

99 

В 

индексных выражений 
Проверка времени ввода 

В 

99 

И 

99 

•• 

данных 

Средства разработки 
Генератор прикладных 

Есть 

• 9 

Есть 

•• 

Есть 

программ 

Функции, создаваемые 

•• 

99 

Нет 

Нет 

I* 

пользователем 

Макроопределения 

•• 

и 

м 

Есть 

•1 

Отладчик программ 


м 

И 

Нет 

Нет 

Псевдокомпилятор 

Нет 

N 

•* 

•* 

Есть 

Поиск и обработка А*НН*Х 
Связь файлов по типу 

•• 

•• 

И 

Есть 

99 

"одна-несколько" записей 
Связь файлов по типу 

Есть 

•• 

«• 

•• 

99 

"несколько-одна” запись 
Связь файлов по типу 

Нет 

Нет 

м 

и 

99 

"несколько-несколько” 

записей 

Обновление нескольких 

•> 

В 

В 

іі 

99 

связанных файлов в одной 
экранной форме 

Связь файла с самим собой 

Есть 

Есть 

Нет 

іі 

Нет 

Запросы на языке $01 

Нет 

99 

*• 

•1 

99 

Команда восстановления 

м 

99 

•• 

Нет 

99 

данных 

Запросы в форме шаблона 

Есть 

99 

»* 

Есть 

Есть 

(по образцу) 

Генеоаиия отчетов 
Отчеты из нескольких 

Нет 

99 

•• 

•• 

н 

файлов 

Создание исходного 

м 

99 

и 

Нет 

•1 

программного файла 
Создание верхних 

Есть 

99 

іі 

Есть 

II 

колонтитулов в отчете 
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Окончание табл. 1.1. 


Характеристика 

Рагасіох 

2.0 

СІВАЗЕ 

IV 

1.0 

сіВАЗЕ 

ІІІ+ 

К:Базе 
Рог 00$ 
2.11 

РохЬазе 

2.10 

Создание нихних 

и 

•• 

«« 

•• 

Нет 

колонтитулов в отчете 
Создание итогов в отчете 

и 

и 

•• 

іі 

Есть 

Создание марок типа 

м 

»• 

Есть 

іі 

іі 

письма 

Общие данные 

Размер файла БД 

2 

1 

1 

2 

1 

в записях (триллион) 
Количество полей в записи 

255 

255 

128 

800 

128 

Количество символов 

4000 

4000 

4000 

4096 

4096 

в записи 

Файлов (таблиц) 

ОПП 

ОПП 

ОПП 

80 

ОПП 

в одной БД 

Количество индексов 

255 

47 

7 

80 

7 

на один файл БД 

Количество полей в одном 

II 

100 

100 

800 

37 

индексе 

Количество связанных 

ОПП 

8 

8 

5 

10 

файлов 

Максимальное число 

•• 

10 

10 

80 

10 

открытых файлов БД 
Максимальное число 

•I 

15000 

256 

ОПП 

3600 

переменных 

Двухмерные массивы 

Нет 

Есть 

Нет 

Нет 

Есть 

Шифрование данных '* 

Есть 

іі 

Есть 

и 

Нет 

Обозначения: ООП - характеристика, ограниченная только емкостью 

оперативной памяти; В - характеристика, реализуемая программно. 


Национальная лаборатория США по тестированию програм¬ 
мных продуктов (Ы5П.) провела анализ быстродействия работы 
СУБД РохЬазе + (версия 2.10), сіВАЗЕ IV (версия 1.0) и сіВАЗЕ 
III + на ПК Сотрая 386 с оперативной памятью емкостью 1 
Мбайт, жестким диском емкостью 130 Мбайт и тактовой частотой 
20 Мггц. Для проведения тестирования использовались БД 
банковских счетов и имитировалась работа кассиров в отделениях 
банка розничной торговли по выполнению стандартных операций 
типа дебет/кредит. 

Проведены шесть тестов скорости выполнения следующих 
операций: 

I тест - индексирование четырех файлов БД: файла счетов 
(50000 записей), файла кассиров (1000 записей), файла отделе¬ 
ний банка 100 записей), файла сделок (1000 записей); 

I! тест - выполнение 1000 стандартных банковских операций 
с файлами без индексирования; 


14 











і, 10 2 с 


1 . 10 ' 


С 


2.5- 

1.5- 
0- 



I тест 



II тест 
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50 
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- РохЬазе 



V тест 



2 

ио^с 



VI тест 

Ц - СІВА5Е IV II - аВА$Е ІІІ + 


Рис. 1.1. Время выполнения тестов 


III тест - выполнение 1000 стандартных банковских операций 
с индексированным по четырем полям файлом из 1000 записей; 

IV тест - выполнение 1000 стандартных банковских операций 
с индексированным по четырем полям файлом из 10000 записей; 

V тест - подготовка отчета с отбором 1000 записей индекси¬ 
рованного файла счетов; 

VI тест - подготовка отчета, аналогичного предыдущему, с 
отбором записей без индексирования файла счетов. 

На рис. 1.1 приведены данные о времени (в секундах) 
выполнения этих тестов. 

Увеличение времени выполнения теста III по сравнению с 
тестом II связано с тем, что при добавлении записей с данными 
о сделках в тесте III затрачивалось время на обновление 
индексов. При обновлении данных в индексированных файлах БД 
затрачивается дополнительное время на переиндексирование, но 
впоследствии применение индексирования дает выигрыш при 
операциях по поиску и отбору данных, например в случае 
подготовки отчетов, что видно из тестов V и VI. 
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1.2. ОБЩАЯ ХАРАКТЕРИСТИКА СУБД 4ВАЗЕ IV 

Сравнительный анализ некоторых СУБД реляционного типа 
показывает, что среди них наиболее универсальными являются 
СУБД семейства сіВАЗЕ. Последняя версия этого семейства сіВАЗЕ 
IV включает существенно улучшенный командный язык. В нем 
сохранены все команды языка сіВАЗЕ III +, многие из которых 
значительно усилены, а также есть совершенно новые команды 
и функции, включая команды по организации меню прикладных 
программ, обработке файлов БД, работе в среде ЛВС и т.д. Как 
уже упоминалось, в языке сіВАЗЕ 111+ слабо представлены 
команды для разработки меню прикладных программ. Обычно 
вместе с СІВАЗЕ 111+ для разработки таких меню используются 
сопутствующие сервисные пакеты типа РІа$Ь-СосІе, 1)$ег Іпіегіасе 
и др. Расширение языка сіВАЗЕ IV командами разработки меню 
прикладных программ устраняет существенный недостаток таких 
возможностей в СУБД сіВАЗЕ III+ . 

В языке сіВАЗЕ IV также предусмотрены средства ввода и 
вывода данных в окна на экране, что является значительным 
развитием системы команд. Особенно усилены в сіВАЗЕ IV по 
сравнению с сіВАЗЕ III + возможности работы с полями типа 
Мето. Предусмотрен поиск по этим полям, вывод информации 
из них в окна, чего не было в сіВАЗЕ III + . 

Кроме этого языка в состав пакета сіВАЗЕ IV введен 
дополнительный командный язык ЗОЬ, специально предназначен¬ 
ный для выполнения сложных запросов на выборку данных из 
файлов БД. Эти команды могут выполняться в режиме ввода с 
клавиатуры или автоматически в виде процедур, вызываемых из 
программ, написанных на языке сіВАЗЕ IV. Сочетание развитого 
языка сіВАЗЕ IV для создания удобного интерфейса пользователя 
в прикладных программах и языка запросов ЗОЕ позволяет 
облегчить разработку сложных программных комплексов 
обработки данных. Процедуры, написанные на языке ЗОЕ, могут 
переноситься в другие СУБД, использующие этот же язык 
программирования, что расширяет сферу применения пакета 
СУБД сіВАЗЕ IV. 

В пакете сіВАЗЕ IV, как и в ранних версиях этого семейства 
СУБД, используются интерпретирующая система и интерфейс 
пользователя с режимом, управляемым с помощью меню, и 
режимом выполнения команд с клавиатуры. В СУБД семейства 
сіВАЗЕ, начиная с версии III+ , введены средства для работы в 
среде ЛВС. При работе в этой среде должна быть исключена 
возможность обращения пользователей, имеющих доступ к 
общим файлам, к одной и той же информации в одно и то же 
время. В сіВАЗЕ IV значительно улучшены средства разрешения 
конфликтов, возникающих в такой ситуации. Введены средства 
автоматического захвата файлов и записей при выполнении 
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команд по обновлению файлов, а также специальные команды, 
позволяющие осуществить захват файлов и записей в них. 

Представление о возможностях пакета сІВАЗЕ IV можно 
получить при знакомстве с управляющим центром (УЦ), 
представляющим собой дальнейшее развитие интерфейса 
пользователя СУБД семейства сІВАЗЕ, управляемого с помощью 
меню. По сравнению с сІВАЗЕ 111+ этот интерфейс настолько 
переработан, что его можно считать совершенно новым продук¬ 
том. В новом интерфейсе систематизированы и расширены 
функции пакета, существенно улучшено оформление меню на 
экранах и организация процесса управления БД. 

По своим возможностям этот интерфейс примерно равен 
аналогичным средствам Рагасіох, а в некоторых отношениях и 
выше. Например, в состав УЦ помимо обычных компонентов 
входит генератор прикладных программ, с помощью которого 
пользователи, не зная команд, могут разрабатывать программы 
средней степени сложности. Специально для профессиональных 
программистов для разработки сложных программных комплексов 
в версии 1.1 пакета сІВАЗЕ IV фирма А$Ьіоп-Таіе предполагает 
поставлять компилятор для создания исполнимых модулей, 
которые можно выполнять на ПК без пакета сІВАЗЕ IV только 
под управлением ОС. 

Выше уже были даны некоторые характеристики СУБД 
семейства сІВАЗЕ, которые относятся и к пакету сІВАЗЕ IV. 
Важной характеристикой является скорость поиска и отбора 
данных. В реляционных СУБД обычно используются два основных 
способа поиска данных: последовательный поиск записей и поиск 
по индексу. При последовательном поиске данных осуществляется 
перебор всех записей файла БД. 

Для поиска по индексу предварительно нужно создать 
вспомогательный индексный файл. Индексный файл содержит 
номера записей файла БД, которые упорядочены по возрастанию 
(или убыванию) индексного выражения, представляющего собой 
одно поле файла БД или комбинацию нескольких полей. Эти 
поля объединяются с помощью операторов отношений, разре¬ 
шенных для соответствующих полей (более подробно об 
операторах отношений см. гл. 3). 

В случае использования индексных файлов поиск заданного 
значения поля (или комбинации полей) выполняется с помощью 
номеров записей индексного файла с использованием метода 
деления отрезка пополам, что значительно ускоряет этот процесс. 
С одним файлом БД может быть связано несколько индексных 
файлов, что позволяет осуществлять поиск по различным полям 
(или их комбинациям). 

Файлы БД постоянно хранятся во внешней памяти ПК - 
обычно на магнитных дисках. Для выполнения действий с файлом 
БД его записи считываются в оперативную память ПК. Перед 
считыванием осуществляется подготовка файла, которая называ- 
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ется открытием файла. Для эффективного использования данных 
в СУБД часто требуется обрабатывать одновременно несколько 
файлов. Перед этим их все надо открыть. Максимальное 
количество одновременно открытых файлов является одним из 
важнейших показателей возможностей конкретной СУБД. Кроме 
файлов БД в оперативной памяти ПК в течение сеанса работы 
с СУБД может размещаться сравнительно небольшой объем 
данных в виде так называемых переменных. Для них отводятся 
определенные участки оперативной памяти. В переменной может 
содержаться любой вид данных, предусмотренных в файлах БД. 
Переменные могут служить промежуточным хранилищем данных 
(буфером) при вводе их с клавиатуры в файлы БД или между 
файлами БД, а также и для других целей, например выполнения 
арифметических и прочих операций. В сіВАЗЕ 111+ используются 
одномерные массивы переменных, тогда как в сіВАЗЕ IV введены 
двумерные массивы. 

Система индексирования полей в сіВАЗЕ IV построена более 
удобно, чем в сіВАЗЕ 111 + . Индексные файлы в отличие от 
сіВАЗЕ 111+ объединяются в один множественный индексный 
файл, связанный с соответствующим файлом БД. Этот файл 
открывается автоматически при открытии связанного с ним файла 
БД, а переход на различные индексы (называемые указателями 
индексов в множественном индексном файле) осуществляется без 
повторного открытия и закрытия неиспользуемых индексов, что 
ускоряет процесс обработки данных. Всего может быть создано 
47 указателей индексов в одном множественном индексном 
файле. 

По сравнению с сіВАЗЕ 111+ в режиме сіВАЗЕ IV, управляе¬ 
мом с помощью меню, реализовано значительно больше 
сервисных операций. В число таких операций входят, например, 
экспорт и импорт файлов других пакетов (І_оіи$ 1-2-3, Ргатеѵѵогк 
II и др.), выполнение команд ЭОЗ без выхода из пакета, выход 
в РОЗ с возвращением обратно, копирование, удаление, 
перемещение и переименование файлов, высвечивание директо- 
риев дисковых устройств, расцветка областей экрана, создание 
макроопределений для автоматического выполнения действий, 
эквивалентных нажатию клавиш на клавиатуре и т.д. 

Система управления базами данных СІВАЗЕ IV значительно 
усилена по сравнению с сіВАЗЕ 111+ по многим параметрам 
(ниже в скобках указаны данные для сіВАЗЕ 111 + ). В частности, 
можно создавать двухмерные массивы переменных общим 
объемом до 1170 элементов, может быть открыто до 99 (16) 
файлов, увеличено максимальное количество переменных - 15000 
(256), количество полей в файлах БД - 255 (128), число 
открытых индексных файлов - 10 (7) и т.д. Как уже отмечалось 
выше, командный язык сіВАЗЕ IV значительно расширен и 
улучшен по сравнению с командным языком сіВАЗЕ III + . 
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Включение в язык сіВАЗЕ IV новых команд позволило 
существенно улучшить следующие функции пакета СУБД 
семейства сіВАЗЕ: разработку иерархических систем меню 
прикладных задач; разработку экранных форм ввода и вывода 
данных; организацию ввода и вывода информации в отдельные 
окна на экране; вывод данных на печать; широкие возможности 
по поиску и обработке данных в файлах БД; обеспечение работы 
в среде ЛВС и др. 

Особо следует отметить в сіВАЗЕ IV встроенный отладчик 
программ, который позволяет перехватывать практически любую 
ошибку и не дать ей распространиться на данные и программы. 
Сделанные улучшения позволяют разрабатывать с помощью 
пакета сіВАЗЕ IV большие программные комплексы, обеспечива¬ 
ющие сложную обработку информации в сочетании с удобством 
работы при эксплуатации. 

К числу недостатков пакета сіВАЗЕ IV можно отнести 
сравнительно медленное выполнение ряда операций интерпрети¬ 
рующей системой (например, генерацию отчетов), а также 
увеличенную потребность в оперативной и дисковой памяти ПК 
по сравнению с другими СУБД (для загрузки пакета требуется 
не менее 640 кбайт оперативной памяти и около 4 Мбайт памяти 
на диске). Системы управления базами данных семейства сіВАЗЕ 
прошли уже весьма длительный путь эволюции. Ввиду безус¬ 
ловно положительного требования совместимости поздних версий 
с ранними в сіВАЗЕ IV сохраняются все команды из сіВАЗЕ III+ , 
нужда в ряде из которых полностью отпадает, так как введены 
новые, более удобные команды. Это увеличивает общий объем 
пакета. В целом пакет весьма громоздкий и для изучения всех 
его возможностей нужно проработать довольно большой объем 
материала. 

Однако недостатки пакета сіВАЗЕ IV являются продолжением 
его достоинств. Многофункциональность, большой объем и 
разнообразие средств управления и обработки БД, высокая 
степень "дружественности" интерфейса, предназначенного для 
пользователей любого уровня подготовки, и развитая среда для 
профессионального программирования позволяют считать сіВАЗЕ 
IV в настоящий момент одним из ведущих пакетов универсаль¬ 
ного предназначения среди СУБД реляционного типа. 



Глава 2 

РАБОТА С УПРАВЛЯЮЩИМ ЦЕНТРОМ 
(СОЫТКОІ. СЕЫТЕР) 

2.1. ОБЩИЕ СВЕДЕНИЯ ОБ УПРАВЛЯЮЩЕМ ЦЕНТРЕ 

Представление о возможностях пакета сІВАЗЕ IV можно 
получить при знакомстве с управляющим центром (УЦ), 
реализующим интерфейс пользователя, управляемый меню. В 
состав УЦ входят шесть меню: 

меню Оаіа ("Данные") для создания, изменения структуры 
файлов БД, ввода, обновления и отображения данных на экране; 

меню Оиегіех ("Запросы") для формирования и выполнения 
запросов на выборку и обновление данных; 

меню Рогпі5 ("Формы") для разработки экранных форм 
ввода и вывода информации; 

меню Керогіх ("Отчеты") для разработки форм отчетов и 
вывода их на печать; 

меню ІаЬеІх ("Марки") для разработки форм марок и 
вывода их на печать; 

меню Арріісаііопх ("Прикладные программы") - генератор 
разработки прикладных программ. 

Функции УЦ и расположение меню на экране отражают 
последовательность работы пользователя при разработке приклад¬ 
ной информационной задачи. Работа обычно начинается с 
создания структуры файлов БД, которые требуются для ее 
решения. Разработка общей структуры БД представляет собой 
творческий процесс, в котором необходимы как знания приклад¬ 
ной информационной задачи, так возможностей конкретной 
СУБД. При этом определяется структура файлов БД, их взаимо¬ 
связь, способы обработки информации и формы вывода данных 
и т.д. 

После создания структур файле" БД прикладной задачи 
требуется ввести в них данные. Ввод может быть осуществлен 
с клавиатуры ПК или из другого файла БД. В процессе эксплуа¬ 
тации информационной задачи возникает необходимость обновле¬ 
ния и ввода новых записей файлов БД. Эти операции могут быть 
выполнены с помощью меню УЦ несколькими способами. При 
обновлении данных вручную с клавиатуры можно использовать 
меню "Данные". В случае обновления больших массивов данных 
из других файлов целесообразно формировать специальные 
запросы на обновление данных с помощью меню "Запросы". 
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Ввод и обновление данных в меню "Данные" выполняется 
на экране в стандартных формах. Эти формы не всегда вполне 
удобны для пользователя. В УЦ предусмотрено меню "Формы", 
позволяющее разрабатывать собственные экранные формы для 
ввода и вывода информации, в которых можно удобно располо¬ 
жить поля записей файла БД, ввести пояснения и другую 
вспомогательную информацию, организовать контроль ввода 
данных и т.д. 

После того как разработана структура файлов данных 
прикладной задачи, отработаны экранные формы для ввода и 
обновления данных, для формирования выходных документов 
требуется отобрать необходимую информацию. Отбор 

информации из одного или нескольких файлов БД можно 
выполнить с помощью меню "Запросы". В состав этой 
информации могут входить не только данные, непосредственно 
находящиеся в файлах БД, но и данные, получаемые в 
результате различных способов обработки записей, например, 
итоговые данные по группам значений полей файлов БД, 
средние, максимальные и минимальные значения групп, 
количество записей в группах, а также результаты различных 
других арифметических операций с значениями числовых полей 
файлов БД. Отобранные данные можно выводить на экран в 
разработанных ранее формах или на печать. 

Меню "Запросы" позволяет также связывать между собой 
несколько файлов БД, что дает возможность при разработке 
структуры файлов БД прикладной задачи избежать дублирования 
информации и тем самым сэкономить внешнюю память, 
увеличить быстродействие задачи и ускорить процесс обновления 
данных. 

Завершающий этап процесса обработки информации - вывод 
полученных данных на экран, принтер или внешние носители. 
Важной стороной данного этапа является представление 
выходных данных в форме, удобной для анализа и оценки. Для 
генерации форм выходных документов предназначено меню 
"Отчеты". Это меню позволяет создавать различные формы 
выводимых документов как по содержанию, так и по размеще¬ 
нию материала с целью его наглядного восприятия. 

Можно выводить на печать уже обработанные данные, не 
изменяя при этом саму БД (примерно так, как это делается в 
запросах на отбор информации). В частности, можно получать 
итоговые численные значения в группах однородной информации, 
выполнять статистическую обработку и арифметические действия 
над полями данных. Кроме того, предусмотрена возможность 
вывода на печать данных, сохраненных на диске после отбора с 
помощью созданных ранее запросов. Для создания сложных 
выходных документов можно использовать данные, полученные 
в результате выполнения запросов, которые затем подвергаются 
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дальнейшей обработке уже в ходе подготовки вывода документа 
на печать. 

Таким образом, меню УЦ позволяет выполнять все этапы 
процесса обработки информации, начиная от ее записи на 
носители и завершая выдачей необходимых выходных докумен¬ 
тов. Этот процесс реализуется посредством выполнения пользова¬ 
телем действий с помощью меню УЦ. Число этих действий 
может быть достаточно велико. Для автоматизации обработки 
данных обычно требуется разработать программу на командном 
языке СУБД, которая затем выполняется в пакетном режиме. 
Чтобы составить такую программу, надо знать систему команд 
СУБД. Меню "Прикладные программы" позволяет создать 
программу работы СУБД, не зная системы команд. В состав этой 
программы могут входить разнообразные меню пользователя для 
прикладной задачи, которые обеспечивают удобство и нагляд¬ 
ность ее эксплуатации и реализацию всех требуемых операций 
в автоматическом режиме. 

Чтобы различать файлы, используемые в СУБД, им присваи¬ 
ваются имена, а для определения типа файла к имени 
присоединяется через точку его расширение. Например, все 
файлы БД в семействе СУБД сіВАЗЕ имеют расширение .СІЫ, 
индексные файлы сіВАЗЕ N1+ - расширение .псіх, а множест¬ 

венные индексные файлы в сіВАЗЕ IV - .тсіх, программные 
файлы - .ргд и т.д. 

Разработанные с помощью УЦ экранные формы, запросы, 
отчеты, марки и прикладные программы представляют собой 
программные файлы, которые записываются в виде файлов с 
различным расширением, характеризующим его тип. Эти файлы, 
как и файлы БД и связанные с ними индексные файлы, хранятся 
в каталогах. Каталог - это файл, в котором хранятся имена и 
место физического расположения группы файлов, объединенных 
определенной целью использования, например, для одной 
прикладной задачи, для одного пользователя и т.д. Каталог 
сходен с директорием, но в отличие от последнего не образует 
иерархической структуры. В директорий включаются файлы по 
месту их расположения на диске, а в каталог - по назначению. 
В каталог могут быть включены файлы из различных директори- 
ев и дисков. Для работы с каталогами в УЦ имеются удобные 
меню, которые описаны в разд. 2.3. 

Здесь не описывается процедура установки пакета, которую 
можно найти в техническом описании. После установки вызов 
пакета может быть выполнен различными способами, в том числе 
с использованием систем меню сервисных пакетов типа Ыогіоп 
Соттапсіег и др. В любом случае вход в пакет осуществляется 
запуском основного исполняемого модуля сІЬазе.ехе из среды 
операционной системы. После входа в сіВАЗЕ IV по умолчанию 
устанавливается режим ввода команд с клавиатуры (высвечива¬ 
ется точка в левом нижнем углу - приглашение для ввода 
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команды). Переход из этого режима в режим, управляемый 
меню, осуществляется командой А$$і$? или нажатием функцио¬ 
нальной клавиши Р2. На рис. 2.1 показан экран УЦ. 

На экране УЦ в верхней строке высвечивается горизонталь¬ 
ное меню, предназначенное для выполнения различных операций 
с файлами. После входа в УЦ всегда высвечивается меню 
сервисных функций, показанное на рис. 2.1. Это меню служит 
для выполнения операций общего назначения. В следующей 
строке помещается английское название управляющего центра, 
затем имя текущего каталога, а далее панель, в которой 
высвечиваются имена файлов из текущего каталога. Под панелью 
высвечивается имя файла, на котором установлен курсор в 
текущий момент и словесное описание этого файла. В нижней 
части экрана размещается информационная строка, в которой 
дается вспомогательная информация (наименования клавиш, 
выполняющих основные операции) и строка сообщений, появля¬ 
ющихся при выполнении позиций меню (эта строка на рис. 2.1 
не показана). 

Панель УЦ состоит из шести окон. Окно йаіа содержит 
имена файлов БД. Окно Оиегіез показывает имена файлов 
запросов на выборку и обновление данных. В окне Рогіш 
высвечиваются имена файлов экранных форм ввода и вывода 
информации. Окно Керогіз содержит имена файлов форм 
отчетов, а окно І.аЬеІ$ - имена файлов форм марок. 

Крайнее справа окно Арріісаііопз высвечивает имена 
программ, разработанных с помощью генератора прикладных 
программ или любых текстовых файлов. После входа в УЦ 
курсор устанавливается в одно из окон и высвечивается меню 
сервисных функций, которые описаны в разд. 2.3. При этом 
меню находится в неактивном состоянии, т.е. высвечиваются 
только горизонтальные позиции в верхней части экрана. Активи¬ 
зация этого меню (и любых других меню) осуществляется 
клавишей РІО. 

Признаком активизации служит появление вертикального 
меню, прикрепленного к одной из позиций горизонтального 
меню. Деактивизация, сопровождающаяся удалением прикреплен¬ 
ного вертикального меню, осуществляется клавишей Е$с (вообще 
клавиша Е$с служит также для отмены любого начатого, но не 
оконченного действия и возвращения к предыдущему состоянию). 
Передвижение по окнам панели УЦ осуществляется клавишами 
со стрелками "Вправо" и "Влево", а внутри окна клавишами 
"Вверх" и "Вниз". 

Для создания файлов соответствующих типов в окнах панели 
УЦ имеется позиция <сгеаіе> (создать). После выбора этой 
позиции высвечиваются экраны, предназначенные для выполнения 
операций по созданию файла соответствующего типа. Эти же 
экраны раскрываются и при выборе имени файла в окне. 
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Оезсгірііоп: Данные о водителях 

Не 1 р:Р1 Узе^- 1 йа1а:Р2 йезідп: 5МР1-Р2 Циіск Йерогі:5ЫР1-Р9 Мепиз:Р10 
Рис. 2.1. Экран управляющего центра 


В верхней части экрана создания (модификации) файла 
высвечивается основное (горизонтальное) меню того окна, из 
которого был выбран файл. Меню каждого окна имеет иерархи¬ 
ческую структуру. Оно состоит из основного горизонтального 
меню и системы вертикальных меню, прикрепленных к позициям 
меню вышестоящего уровня. В любом меню выполняемыми 
обычно являются позиции самого нижнего уровня. Неисполняе¬ 
мые позиции меню, которые служат для перехода на нижеследу¬ 
ющий уровень, обычно помечаются знаком треугольника слева 
от названия позиции. Выход на выполняемую позицию осущест¬ 
вляется посредством последовательного раскрытия меню 
нижестоящих уровней. Ниже в тексте под термином меню будет 
подразумеваться как меню определенного окна в целом, так и 
неисполняемые позиции меню, к которым прикреплены верти¬ 
кальные меню нижеследующего уровня (обычно позиции 
основного - горизонтального меню окна). Из контекста будет 
ясно, о каком меню идет речь. 

Для того чтобы быстрее научиться работать с УЦ, нужно 
прежде всего освоить операцию выбора, которая является 
главной среди остальных действий, выполняемых на клавиатуре. 
Операция выбора состоит из двух основных действий: передви¬ 
жения курсора на требуемую позицию и нажатия клавиши Епіег 
(выполнение действия, связанного с операцией выбора). 
Передвижение курсора на одном уровне меню осуществляется 
навигационными клавишами (Вправо, Влево, Вверх, Вниз, РдІІр, 
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РдОп, Ноте и Еп<1). Раскрытие меню нижеследующего уровня 
осуществляется клавишей Епіег, естественно, после установки 
курсора на соответствующую позицию. Чаще всего операция 
выбора применяется при выборе позиции меню и файла в окне 
Оаіа. Кроме того, при работе с УЦ нередко используется 
операция выбора необходимого значения (оператора, перемен¬ 
ной, данных, имен файлов и т.д.) из списка значений. Список 
значений вызывается на экран клавишами 5НІК-Р1 или при выборе 
позиции меню. При этом может высвечиваться сразу весь список 
или же одно значение из этого списка. Например, при вызове 
клавишами 5НІМ-Р1 высвечивается сразу весь список. Если 
высвечивается только одно значение, то другие можно вызвать 
последовательным нажатием клавиши Пробел. После установки 
курсора на требуемое значение или вызова клавишей Пробел, 
его выбор также завершается клавишей Епіег. Таким образом, 
операция выбора из списка также состоит из двух основных 
действий, но может включать дополнительные действия по 
Нажатию клавиши Пробел. 

Отметим, что обычно выбору значения из высвечиваемого 
списка есть альтернатива - можно просто ввести требуемое 
значение с клавиатуры. Однако нужно подчеркнуть, что система 
предложения на выбор значений в сІВАЗЕ IV специально предус¬ 
мотрена для избежания ошибок и сокращения времени ввода. 
Поэтому целесообразно выбирать требуемые значения из предос¬ 
тавляемого списка, а не вводить с клавиатуры. 

Иллюстрацию возможностей УЦ лучше всего проводить на 
конкретной задаче. Ниже будет рассмотрена информационная 
задача, на примере которой будут продемонстрированы функции 

УЦ. 


2.2. ЗАДАЧА УЧЕТА И КОНТРОЛЯ РАБОТЫ 
ТРАНСПОРТНЫХ СРЕДСТВ 

Рассмотрим задачу учета перевозок грузов автотранспортным 
предприятием, в парке которого имеются автомобили различных 
марок. Требуется автоматизировать учет и контр>оль работы 
транспортных средств по следующим комплексам данных: маршрутам 
и времени перевозок, перевозимому грузу, состоянию и местонахож¬ 
дению автомобиля и его характеристикам, персональным данным 
о водителях. 

Маршрут и время перевозок включают: пункт погрузки; пункт 
разгрузки; пройденное расстояние; дату выезда; дату прибытия 
в пункт разгрузки. 

По перевозимому грузу учитываются следующие данные: 
наименование груза; организация, отправляющая груз; организация, 
получающая груз; вес груза. 



Состояние автомобиля определяется его исправностью или 
неисправностью, а местонахождение зависит от того, где он 
находится - в рейсе, в автопарке или в капитальном ремонте. 
Технические характеристики автомобиля включают: среднюю скорость 
движения, км/ч; грузоподъемность, т; расход топлива л/км; марку 
автомобиля; номерной знак. 

Данные с водителе содержат: фамилию, имя, отчество; анкетные 
данные (автобиографию); номерной знак автомобиля, на котором 
работает. 

На основании перечисленных выше данных требуется периодически 
выдавать статистику количества перевозимого груза, пройденного 
километража, расхода топлива, состояния автомобилей и т.д. Если 
попытаться представить всю информацию в виде одного файла 
БД, то такой файл получится очень громоздким, многие данные 
будут дублироваться, будет очень сложно выполнять операции 
по поиску, отбору и обновлению данных, в силу чего работать 
с таким файлом практически невозможно. Поэтому для обеспечения 
эффективного выполнения операций по обработке информации 
необходимо сначала провести анализ и определить структуру БД 
в виде связанных между собой файлов БД. Анализ нашей 
информационной задачи показывает, что для учета и контроля работы 
транспортных средств целесообразно создать четыре файла БД 
с именами: В01, В02, ВОЗ и В04: 

В01 - данные о водителях; 

В02 - имеющиеся на предприятии автомобили; 

ВОЗ - перевозимый груз и маршруты движения; 

В04 - технические характеристики автомобилей. 

Файл БД В01 содержит поля с именами: 

ЫОМ - табельный номер водителя; 

РАМ - фамилия; 

НАМ - имя; 

отс - отчество; 

0_К - дата рождения; 

$_К - стаж работы; 

КАТ - категория; 

АІІТО - автобиография; 

Ы_2 - номерной знак автомобиля, на котором водитель 

работает. 

Файл БД В02 включает поля: 

N„2 - номерной знак автомобиля; 

$05 - техническое состояние; 

МАК - марка автомобиля; 

6_Н - местонахождение ( в рейсе, в автопарке, в капитальном 

ремонте). 

Файл БД ВОЗ содержит поля: 

Ы_С - наименование груза; 

0_Р - откуда перевозится груз; 

0_Ѵ - дата выезда; 
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К_й - куда необходимо доставить груз; 

- дата прибытия; 

КА$ - пройденное расстояние; 

ѴКМ - время, затраченное на дорогу; 

ѴЕ5 - масса груза; 

РСК - фактический расход горючего; 

И_2 - номерной знак автомобиля, перевозящего груз. 

Файл БД ІДО4 включает поля: 

МАК - марка автомобиля; 

$КК - средняя скорость движения, км/ч; 

СК2 - грузоподъемность, т; 

К$Х - номинальный расход топлива, л/км. 

Общие поля файлов БД служат для их связки. На основе этих 
связей образуется интегрированная база данных, в которой хранится 
информация о водителях, транспортных средствах и перевозимых 
грузах. Схема связи файлов БД представлена на рис. 2.2. 

В качестве самостоятельной работы попытайтесь расширить 
эту задачу в отношении учета и хранения дополнительных данных. 

Например, файл БД ЕЮ1 можно дополнить полями, учитывающими 
информацию для отдела кадров и вводить в него данные не только 
на водителей, но и на остальных служащих предприятия (поля 
должности, номера отдела и т.д.). 

Для финансового отдела можно создать новый файл БД В05, 
в котором хранится информация о количестве рабочих дней, размере 
начислений и удержаний, необходимых для расчета заработной 
платы. 


ВЭ1 - водители 


- номерной знак 

”1 



Вй2 - автомобили 


Н_1 - номерной знак 

— 

МАЙ - марка 

п 


ВйЗ - груз 
Н_1 - номерной знак 


ВЭ4 - ТХ автомобилей 
МАЙ - марка 

Рис. 2.2. Схема связи файлов БД автопредприятия 
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Автоматизируя складской учет, можно создать файл БД ВР6 
для хранения данных о материально-техническом обеспечении ( МТО). 

Тогда можно построить базу данных для автоматизированной 
системы управления (АСУ) автопредприятия, включающую в себя 
подсистемы учета перевозок, учета автотранспортных средств, 
материально-технического обеспечения, а также кадровую и финансовую 
подсистемы. Структурно АСУ автопредприятия можно представить 
так, как показано на рис. 2.3. 

Изучение материалов по сіВАЗЕ IV базируется на самостоятельной 
работе по решению примеров, приводимых в последующих разделах. 
Если читатель встретит трудности, то он может обратиться к учебной 
дискете, на которой записаны все решения этих примеров. 

Решения записаны на учебной дискете в директорие РКІМЕК, 
который включает четыре файла БД (ЕШ1, ІШ2, ВОЗ, ВР4), 18 
запросов (ООІ - 018), четыре экранные формы (Р1 - Р4), отчет 

К1, марку И, прикладную программу с именем АѴТО и два текстовых 
файла ТЕХТ1 и ТЕХТ2. Файлы учебного примера с дискеты 
целесообразно скопировать на жесткий диск. Предлагаемые примеры 
можно решать и записывать их результаты в тот же директорий, 
в котором находятся учебные примеры, считанные с дискеты. 

Имена создаваемых Вами файлов должны отличаться от файлов 
учебной дискеты. При одинаковых именах новый создаваемый файл 
записывается на место старого, так что файл учебной дискеты будет 
заменен созданным Вами файлом. 

Копирование учебной дискеты на жесткий диск можно выполнить 
средствами сЗВАЗЕ IV или 005. Поскольку Вы еще практически 
не приступили к изучению пакета, покажем, как копировать, находясь 
в среде 005. В следующем разделе будет описано как это сделать 
средствами СІВА5Е IV. Перед копированием целесообразно создать 
в директории РВА5Е поддиректорий, например с именем РВІМЕВ, 
куда и будет копироваться содержимое директория РКІМЕК дискеты. 



Рис. 2.3. Подсистемы АСУ автопредприятия 
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Эти операции удобно выполнять с помощью пакета программ 
ІЧсгіоп Соттапсіег (запуск этого пакета, если он не осуществлен 
при загрузке Вашего компьютера, реализуется в среде РОЗ вводом 
с клавиатуры имени ЫС (или ЫСЗМАІ.І-) и последующим нажатием 
клавиши Епіег). Затем, находясь уже в среде пакета Ыогіоп Соттапсіег, 
нажмите одновременно клавиши АІІ-Р1, и в высветившемся окне 
выберите имя логического диска ( С,Р,Е,Р и т.д.), в котором находится 
сіВАЗЕ IV (предположим, что сіВАЗЕ IV расположен на диске 
й:), и нажмите клавишу Епіег. В левой панели высветится содержимое 
выбранного диска. Если курсор находится в правой панели, то с 
помощью клавиши ТАВ переместите его в левую панель экрана. 

Затем установите курсор на директорий РВАЗЕІѴ ( на различных 
компьютерах имя этого директория может варьироваться, например, 
ЭВА5Е4, ЬВ4, ЭВАЗЕ и т.д., что определяется тем, как был задан 
директорий при установке пакета сіВАЗЕ IV) и нажмите клавишу 
Епіег. Тем самым Вы войдете в директорий йВАЗЕІѴ. Затем нажмите 
клавишу Р7 для создания поддиректория РКІМЕК. После этого появится 
окно, в котором записано имя текущего диска и директория, например, 
0:\0ВА$ЕІѴ. Дополните маршрут именем поддиректория с ведущей 
наклонной чертой влево 0:\0ВА$ЕІѴ\РКІМЕК и нажмите клавишу 
Епіег (для новой версии ІЧогіоп Соттапсіег текущий директорий 
в окне не высвечивается, поэтому нужно вводить с клавиатуры 
весь маршрут 0:\0ВА$ЕІѴ\РКІМЕК). Поддиректорий РКІМЕК директория 
РВАЗЕІѴ создан. Установите курсор на созданный поддиректорий 
РКІМЕК и нажмите клавишу Епіег для его раскрытия. 

Теперь скопируйте в этот поддиректорий содержимое директория 
РКІМЕК дискеты. Для этого нажмите клавиши АІІ-Р2, в высветившемся 
окне выберите диск А: и нажмите клавишу Епіег. В правой панели 
ІЧогІоп Соттапсіег высветится содержимое дискеты. Клавишей ТАВ 
перейдите на правую панель с содержимым дискеты, установите 
курсор на директорий РКІМЕК и раскройте его содержимое клавишей 
Епіег. Для выбора всех файлов директория РКІМЕК нажмите клазѵхіу 
" +" (Сгау РІи$) справа от цифровой клавиатуры и затем Епіег. 
При этом все выбранные файлы будут выделены желтым цветом. 
Для копирования файлов с дискеты на жесткий диск нажмите клавишу 
Р5, после чего высветится окно, в котором записан маршрут по 
директориям 0:\0ВА$Е1Ѵ\РКІМЕК, куда копируется дискета и, 
убедившись в правильности этого маршрута, нажмите клавишу Епіег. 
После этого файлы будут последовательно копироваться с визуальным 
отображением объема копируемого файла. 

Отметим, что при разработке и эксплуатации информационных 
задач часто требуется выполнять операцию обратного копирования: 
с жесткого диска на дискету. Эта операция выполняется подобно 
описанной, с той лишь разницей, что подсвечивать надо уже файлы 
на жестком диске ( которые копируются). Вообще для всех операций 
копирования действует правило: надо высветить копируемые файлы, 
безразлично в какой половине экрана и установить клавишей ТАВ 
курсор на эту половину. После нажатия клавиши Р5 подсвеченные 
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файлы копируются на диск в директорий, который установлен в 
другой половине экрана. Отметим также, что подсветка 
отдельных файлов выполняется клавишей Іп$, а гашение подсвет¬ 
ки отдельного файла - повторным нажатием этой клавиши. 
Гашение всех подсвеченных файлов осуществляется нажатием 
клавиши , расположенной выше клавиши " +", с помощью 
которой выполнялась подсветка, и последующим нажатием 
клавиши Епіег. Заметим, что при копировании одного файла его 
имя можно не подсвечивать - достаточно установить на нем 
курсор. 


2.3. СЕРВИСНЫЕ ФУНКЦИИ УПРАВЛЯЮЩЕГО ЦЕНТРА 

Перед тем как начать изучать основные функции УЦ, 
рассмотрим его сервисные функции. При входе в УЦ всегда 
сначала высвечивается меню сервисных (обслуживающих) 
функций, включающее три позиции (меню): Саіаіод, ТооІ$ и 
Ехіі 

Меню Саіаіод позволяет создавать каталоги файлов. Каталог 
представляет собой файл, который содержит список файлов 
(обычно одной предметной области), размещаемых на одном 
или нескольких дисках, в том числе и на сменных. В каталоге 
записываются имена файлов, их местоположение и краткое 
словесное описание. Каталог имеет сходство с директорием, но 
между ними есть и существенные различия. Директорий так же, 
как и каталог, представляет собой файл, содержащий список 
файлов. Но в директории в отличие от каталога файлы размеще¬ 
ны на одном диске. Если файл удаляется из директория, то он 
автоматически удаляется с диска. Удаление же файла из каталога 
не вызывает его удаления с диска. Один и тот же файл можно 
занести в несколько различных каталогов. 

Важнейшая особенность системы каталогов сІВАБЕ IV состоит 
в том, что после загрузки каталога все его файлы автоматически 
высвечиваются на панели УЦ. Другой особенностью этой системы 
является автоматическая каталогизация, т.е. автоматическое 
помещение в текущий каталог всех создаваемых в текущем 
сеансе файлов. Третья особенность - это автоматическая 
фильтрация файлов и размещение их на панели УЦ в соответ¬ 
ствующее окно. Так, файлы БД всегда высвечиваются только в 
окне Оаіа, файлы запросов - в окне Оиегіе$ и т.д. Кроме того, 
если требуется загрузить файлы определенного типа из другого 
директория в текущий каталог, то в вызванном списке файлов 
этого директория высвечиваются только файлы этого типа. 

При входе в УЦ автоматически загружается каталог, который 
использовался в предыдущем сеансе. Если раньше не было 
создано ни одного каталога, то при наличии в текущем директо¬ 
рии хотя бы одного файла БД (с расширением .сІЫ) автомати- 
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чески создается и становится текущим первоначальный каталог с 
именем ЦпіМесі.саі. Таким образом, при работе с УЦ практически 
всегда имеется текущий каталог, в который автоматически 
записываются все создаваемые файлы. 

Если в текущем директории нет файлов БД, то каталог 
остается пустыМ до тех пор, пока не будут созданы или 
скопированы файлы этого типа. Для установки в ходе сеанса 
другого каталога нужно выбрать позицию ІІ$е а (Іійегеп! саіаіод 
меню Саіаіод. При этом высвечивается список имен всех 
имеющихся в текущем директории каталогов. Выбор требуемого 
каталога приводит к его загрузке, и он становится текущим. Это 
отмечается на экране УЦ в верхней его части: после слова 
СЛТЛЮО: помещается имя текущего директория (маршрут по 
директориям) и имя текущего каталога. 

Усвоение данного руководства будет глубже, если самостоя¬ 
тельно выполнить все приводимые ниже примеры. Для этого 
целесообразно создать собственный каталог и открывать его в 
каждом сеансе учебного курса. В этот каталог будут заноситься 
все создаваемые Вами файлы. 

Перед созданием каталога активизируйте меню сервисных 
функций нажатием клавиши РІО. Активизация сопровождается 
высвечиванием прикрепленного меню. Выберите позицию Ц$е а 
сііНегепі саіаіод меню Саіаіод, т.е. установите на нее курсор и 
нажмите клавишу Епіег. В правой верхней части экрана высветит¬ 
ся список уже имеющихся в текущем директории каталогов. В 
верхней части списка находится позиция <сгеаіе>, которая 
служит для создания нового каталога. После выбора этой 
позиции высвечивается предложение Епіег пате Іог пеж саіаіод 
(введите имя нового каталога) и окно для ввода имени 
каталога, в котором уже указан маршрут по директориям, т.е. 
имя диска и последовательность имен директориев, разделенных 
косой чертой. Остается только ввести имя каталога, например, 
свою фамилию или ее аббревиатуру и нажать клавишу Епіег. 
После этого высветится экран УЦ, где в качестве текущего будет 
созданный Вами каталог. 

Если имя каталога оказалось неудачным, его можно изме¬ 
нить, выбрав позицию Мосіііу саіаіод пате. Стирание имени 
осуществляется клавишами Васк$расе (удаление символов слева 
от курсора) или Оеі (удаление символа на позиции курсора). 
Для удобства поиска своего каталога, например, в случае, если 
Вы забыли его имя, можно ввести словесное описание каталога, 
которое будет высвечиваться в левой части экрана при выборе 
имени каталога из списка. После выбора позиции Есііі сіезсгірііоп 
о( саіаіод меню Саіаіод и нажатия клавиши Епіег высвечивается 
окно, в которое с клавиатуры введите описание ка/алога, 
например: "Каталог учебных файлов Иванова И.И." В том случае, 
если каталог оказался не нужным, его можно удалить тем же 
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способом, каким удаляется любой файл, учтя что файл каталога 
имеет расширение .саі (об удалении файла см. ниже). 

Как уже указывалось, в текущий каталог будут заноситься 
все создаваемые Вами файлы. Однако нередко требуется 
поместить в каталог другие, ранее созданные файлы. Для этого 
используется позиция АсісІ (ііе іо саіаіод. После выбора этой 
позиции в правой части экрана высвечивается список файлов и 
поддиректориев текущего директория. Раскрытие поддиректория 
выполняется так же, как и меню, - клавишей Епіег. Для 
переноса файла из директория в свой каталог нужно его 
выбрать, т.е. установить курсор на имя файла и нажать клавишу 
Епіег. После этого на экране появится окно с предложением 
ввести словесное описание этого файла, которое будет впослед¬ 
ствии высвечиваться при выборе файла в окне Оаіа. Ввод 
описания файла осуществляется так же, как и ввод описания 
каталога: вводится с клавиатуры текст, а затем нажимается 
клавиша Епіег, что означает завершение ввода текста и его 
запись на диск. Такое завершение является стандартным для 
многих операций по вводу данных. 

После переноса файла из директория в Ваш каталог его имя 
появляется в соответствующем окне экрана УЦ, т.е. файл БД 
появляется в окне Оаіа, файл экранной формы - в окне Рогт$ 
и т.д. Если описание файла оказалось неудачным, его можно 
изменить. Для этого надо установить курсор на имя файла в 
соответствующем окне и затем выбрать позицию СНапде 
сіезсгірііоп о! ЬідЫідМесІ Іііе. После этого высветится окно для 
ввода нового или коррекции имеющегося описания файла, 
которые выполняются так же, как и ввод первоначального 
описания. 

Ненужный файл можно исключить из каталога. Напомним, 
что это не означает удаления файла с диска. Просто имя 
удаленного из каталога файла уже не будет высвечиваться на 
панели УЦ при загрузке данного каталога. Перед исключением 
какого-либо файла из каталога нужно его сначала закрыть, если 
он еще не закрыт. Признаком того, что файл закрыт или открыт 
служит его размещение над чертой в окне на панели УЦ (файл 
открыт) или под чертой (файл закрыт). Процесс закрытия файла 
начинается с его выбора, т.е. установки курсора на его имя и 
нажатия клавиши Епіег. Затем высвечивается горизонтальное 
меню, в котором нужно выбрать позицию (крайнюю левую) 
СІозе Іііе, после чего файл закрывается, что отмечается его 
перемещением ниже черты на панели УЦ. 

При работе с любыми файлами, в том числе с файлами 
учебных примеров, рекомендуется закрывать файлы, которые в 
данный момент не нужны. В этом случае работа СУБД будет 
более стабильной. Практика показывает, что если оставляется 
открытым ненужный файл, то это может привести к весьма 
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тяжелым последствиям, вплоть до того, что файл перестанет 
читаться. 

Как читатель уже догадывается, перед выполнением любых 
манипуляций с файлом нужно установить курсор на его имя в 
соответствующем окне. Так, для удаления закрытого файла из 
каталога нужно предварительно установить курсор на его имя и 
затем выбрать позицию Кетоѵе ЬідЫідНіесІ іііе (гот саіаіод. 
После этого высвечивается предупреждающее сообщение. В этот 
момент можно еще отказаться от удаления файла из каталога 
(ответ Ио) или подтвердить удаление (ответ Ѵез). После 
удаления файла из каталога высвечивается предложение на 
удаление файла из директория на диске. Это уже означает 
уничтожение файла. Здесь надо быть осмотрительным и не 
спешить, так как уничтоженный файл восстановить средствами 
сІВАЗЕ IV уже невозможно. 

При разработке запросов, форм, отчетов, марок и приклад¬ 
ных программ генерируется несколько типов программных 
файлов: файл разработки, файл сгенерированных кодов и 
компилированный файл. Файл разработки служит для 
последующей генерации второго типа файла - программного 
модуля, который в свою очередь преобразуется в исполнимый 
модуль (компилированный) файл. Исполнимый программный 
файл является конечным продуктом генерации соответствующего 
объекта (экранной формы, запроса и т.д.). При этом другие 
файлы (разработки и сгенерированных кодов) при выполнении 
компилированного файла уже не требуются, однако они будут 
нужны, если потребуется изменить этот файл. В зависимости от 
этого определяется необходимость хранения файла разработки 
и сгенерированных кодов. В табл. 2.1 представлены типы файлов 
и их расширения. 


Таблица 2.1. Типы файлов 


Файл 

Окно УЦ 

Файл 

разработки 

Файл 

кодов 

Исполнимый 

файл 

БА 

йаіа 

. сІЬТ 

_ 

_ 

Запрос на выборку 

Оиегіез 

. яЬе 

- 

. дЬо 

Запрос на обновление 

И 

. ирсі 

- 

. иро 

Выборка сІВАЗЕ ІІІ+ 

н 

. ѵие 

- 

- 

Экранная форма 

Гогшз 

.5СГ 


Лто 

Отчет 

Йерогіз 

.^гт 

.^гд 

.?го 

Марка 

1_аЬе1з 

ЛЫ 

. ІЬд 

. ІЬо 

Прикладная программа 

Арр1 ісаііопз 

- 

• ргд 

. сІЬо 

$(}1- программа 

И 

- 

. ргз 

. сіЬо 

Программа, созданная 
генератором прикладных 
программ 

• V 

.арр 

.ргд 

.сіЬо 


2 - 6340 Г* 
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В ряде случаев возникает необходимость перевода созданных 
файлов из одного каталога в другой. Для форм, отчетов и 
марок можно вводить в каталог только файлы разработки и 
исполнимые файлы. Файлы сгенерированных кодов создаются и 
вводятся в каталог автоматически при создании соответствующих 
объектов (форм, запросов и т.д.). Если в каталог вводится 
только файл разработки, то файл кодов и исполнимый файл 
включаются в каталог автоматически. 

Можно вводить в каталог только исполнимые файлы, 
например в случае отсутствия файлов разработки и сгенерирован¬ 
ных кодов, однако, как уже указывалось, модифицировать такие 
исполнимые файлы уже нельзя. В табл. 2.2 показаны файлы, 
которые можно ввести в каталог и которые высвечиваются в 
нем. 

Меню Тооіз обеспечивает средства для облегчения и 
удобства работы пользователя на клавиатуре (создание макро¬ 
определений), позволяет выходить в ІЮ5 из сІВАЗЕ IV, 
выполнять команды 005 и возвращаться в сІВАЗЕ IV, выполнять 
установки параметров сІВАЗЕ IV, создавать защиту данных от 
несанкционированного доступа и схемы ограничения доступа к 
файлам, экспортировать свои и импортировать внешние файлы, 
копировать и переименовывать файлы, а также выполнять другие 
функции. 

После выбора меню Тооіз высвечивается вертикальное меню 
с позициями: Масгоз, ІтрогР, ЕхрогІ, 005 иііііііез, РгоіесТ сіаіа, 
ЗеРРіпдз. 

Позиция Масгоз служит для создания макроопределений - 
программ, имитирующих нажатие любой последовательности 
клавиш клавиатуры, включая вызов меню, выбор его позиций и 
т.Д. 


Таблица 2.2. Типы файлов в каталоге 


Файл 

Окно УЦ 

Вводимые 

файлы 

Высвечиваемые 

файлы 

БА 

йаіа 

.сіЬР 

.сіЬР 

Запрос на выборку 

Оиегіез 

. чЬе, . яЬо 

.цЬе 

Запрос на обновление 


. ирсі, . иро 

.ирсі 

Выборка сІВАЗЕ ІІІ + 

И 

. ѵие 

.ѵие 

Экранная форма 

Рогтз 

.зсг,.Рто 

.зсг, .Ртѣ 

Отчет 

Керогѣз 

.Ргт, .Рго 

.Ргт,.Ргд 

Марка 

І_аЬе1з 

ЛЫ,. ІЬо 

.1Ы, ЛЬд 

Прикладная программа 

Арр1 ісаѣіопз 

. ргд, . сіЬо 

- 

301 программа 


.ргз, .сіЬо 

- 

Программа генератора 

•9 

.арр,.ргд 
.сіЬо 

.ехе,.сот 

.арр 

прикладных программ 
Внешние программы 

99 

- 
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Макроопределение вызывается одной из функциональных 
клавиш Р1-Р9, комбинацией клавиши МО и латинской буквы или 
несколькимии латинскими буквами (только для системных 
макроопределений). Для вызова макроопределения с клавиатуры 
нужно нажать клавишу АН и, удерживая ее, нажать функциональ¬ 
ную клавишу или букву. 

Затем клавишу АІі нужно отпустить и нажать последующие 
буквы. Макроопределения хранятся в библиотеках. Каждая 
библиотека записывается на диск с уникальным именем и может 
включать до 35 макроопределений. 

В макроопределения можно включать другие макроопреде¬ 
ления и создавать вложенные структуры макроопределений (до 
16 уровней). Нельзя делать вложения самих в себя. Для всех 
меню в СІВА5Е IV имеются системные макроопределения, 
которые вызываются последовательностью первых букв имен 
позиций, ведущих к требуемой позиции. 

Например, выход из СІВА5Е IV с панели УЦ можно 
выполнить клавишами АІі-ея (клавиша АН нажимается вместе с 
буквой е, затем отпускается). Пользователи могут создавать и 
модифицировать только макроопределения, вызываемые функ¬ 
циональными клавишами Р1-Р9 или комбинацией клавиши РІО и 
буквы. 

После выбора позиции Масгоз высвечивается меню, позволя¬ 
ющее выполнять операции по созданию макроопределения, его 
модификации, удалению, копированию, изменению имени и 
текста макроопределения, вводу в текст макроопределения точек 
прерывания, сохранению макроопределения в библиотеке на 
диске и др. 

Для создания макроопределения выбирается позиция Ведіп 
гесогсііпд. После этого высвечивается таблица с функциональными 
клавишами Р1-Р10 и буквами, которые служат для вызова 
макроопределений. При первом назначении макроопределения 
функциональной клавише или комбинации клавиши РІО и 
латинской буквы ему присваивается имя - соответственно Р1-Р9 
или латинская буква. Это имя появляется в соответствующей 
графе таблицы (в верхней части таблицы имена макроопреде¬ 
лений, присвоенные функциональным клавишам, а в нижней 
части - комбинациям клавиши РІО и буквы от а до 2 ). В 
последующем первоначально назначенное имя можно изменить 
с помощью позиции Иате на имя, состоящее из любых вводи¬ 
мых с клавиатуры символов. Следует отметить, что созданные 
пользователем макроопределения вызываются с клавиатуры 
только первоначально назначенными функциональными клавишами 
или комбинацией функциональной клавиши РІО и буквы, а имя 
в таблице макроопределений используется только для вызова 
макроопределения с помощью команды РІау тасго. В дальней¬ 
шем для упрощения изложения будем говорить, что макроопре¬ 
деления связываются с функциональными клавишами, подразуме- 
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вая под ними и комбинацию функциональной клавиши РІО и 
буквы. 

Чтобы записать новое макроопределение, требуется нажать 
соответствующую функциональную клавишу (или комбинацию 
клавиши РІО и буквы). Если эти клавиши уже заняты макроопре¬ 
делением, то нужно подтвердить решение о его перезаписи. 
После этого таблица и меню исчезают с экрана и можно вводить 
новое макроопределение, т.е. нажимать последовательность 
клавиш, которая войдет в состав макроопределения. При нажатии 
клавиш будут выполняться связанные с ними действия. Ввод 
макроопределения завершается клавишами 5НІК-Р10 и латинской 
буквой е или выбором позиции Епсі гесогсііпд. 

После того как макроопределение создано, его можно 
модифицировать посредством добавления в его конец новой 
последовательности нажатий клавиш или изменением текста 
макроопределения. Первый способ реализуется выбором позиции 
АррепсІ іо тасго. Затем надо выбрать (нажать) соответству¬ 
ющую функциональную клавишу и приступить к дополнению 
макроопределения, как и при его создании, т.е. нажать клавиши 
в требуемой последовательности. Эта последовательность будет 
добавлена в конец уже имеющегося макроопределения. Второй 
способ модификации уже созданного макроопределения заключа¬ 
ется в редактировании текста макроопределения с помощью 
текстового редактора. Этот способ реализуется выбором позиции 
Мосіііу. Затем нужно нажать функциональную клавишу для 
высвечивания текста макроопределения. В этом тексте действия 
по нажатию буквенных клавиш записываются в виде букв, а 
специальных клавиш - в виде слов в фигурных скобках. Напри¬ 
мер, клавиши Вверх, Вниз, Вправо и Влево представляются 
соответственно в виде слов {ираггож}, {сіоѵѵпаггож}, {ІеНаггож}, 
{гідЬіаггож}. Допускается запись любыми буквами - строчными и 
прописными. Например, если требуется ввести в макроопределе¬ 
ние вызов другого макроопределения, то вводится текст, в 
который входит команда выполнения макроопределения: РІ.АѴ 
МАС&О тасго1{Епіег), где тасгоі - имя макроопределения. В 
макроопределение можно ввести точку прерывания. Она дает 
возможность выполнять с клавиатуры различные операции, 
например вводить данные в файлы БД и др., после чего 
выполнение макроопределения возобновляется нажатием клавиш 
5МН-Р10. Ввод точки прерывания осуществляется в ходе создания 
макроопределения. Для этого следует нажать клавиши 5ЫН-Р10 
и выбрать позицию Іп$егІ изег-іприі Ьгеак. Затем создание 
макроопределения продолжается и завершается, как обычно. 
Можно ввести несколько точек прерывания. 

Макроопределение можно скопировать, связав с другой 
функциональной клавишей, посредством выбора позиции Сору. 
Затем следует нажать копируемую функциональную клавишу и 
ту клавишу, в которую копируется макроопределение. При 
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копировании можно изменить или оставить без изменения имя 
скопированного макроопределения. Уничтожение макроопределе¬ 
ния выполняется выбором позиции Реіеіе и последующим 
нажатием требуемой функциональной клавиши. Для пробного 
запуска созданного макроопределения можно использовать 
позицию РІау, после выбора которой высвечивается таблица имен 
макроопределений. Запуск из этой таблицы осуществляется 
нажатием соответствующей функциональной клавиши. Макроопре¬ 
деление всегда выполняется с текущей позиции курсора. Если эта 
позиция отличается от позиции в момент создания макроопреде¬ 
ления, то это может привести к результату, который не предпо¬ 
лагался. 

Для сохранения созданных макроопределений в текущей 
библиотеке выбирается позиция Заѵе ІіЬгагу. Если библиотека не 
создана, то высвечивается окно, в которое следует ввести имя 
библиотеки. Не сохраненные макроопределения после заверше¬ 
ния текущего сеанса теряются. Загрузка ранее созданной 
библиотеки макроопределений осуществляется выбором позиции 
Ьоасі ІіЬгагу. Если в момент загрузки имеется текущая библиоте¬ 
ка, то высвечивается предупреждение для ее сохранения, 
которое можно сделать в этой же точке. 

После сохранения или подтверждения не сохранять текущую 
библиотеку высвечивается список библиотек. После загрузки 
новой библиотеки ее макроопределения перекрывают старые, 
если они записаны под одним именем. В противном случае 
макроопределения старой библиотеки не заменяются и остаются 
действующими. Это позволяет комбинировать в оперативной 
памяти макроопределения из различных библиотек. 

Макроопределение можно создать также из любого места 
пакета сІВАЗЕ IV, вызвав сокращенное меню клавишами ЗНІЙ-Р10. 
После этого высвечивается горизонтальное меню с позициями 
Ведіп гесогсіегіпд и СапсеІ. Создание макроопределения осущест¬ 
вляется выбором первой из этих позиций. Вторая позиция 
позволяет отменить эту операцию. 

Позиция Ітрогі меню ТооІ$ дает возможность переносить в 
сІВАЗЕ IV внешние по отношению к нему файлы, присваивая им 
расширение .<ІЫ. При этом поля записей сохраняют свои типы 
данных, созданные во внешних файлах. После выбора позиции 
Ітрогі высвечивается меню с опциями, реализующими выбор 
типа файла. Выбор типа файла приводит к высвечиванию списка 
файлов этого типа в текущем директории. Выбранный файл 
затем переносится в сІВАЗЕ IV. Если такое имя уже есть в 
сІВАЗЕ IV, то высвечивается предложение выполнить ’ операцию 
или прекратить ее. 

Можно импортировать следующие типы внешних файлов: 
Карісііііе (файлы с расширением .грсі), файлы БД сІВАЗЕ II (для 
импорта этого типа файлов необходимо изменить их расширение 
с .сіЬІ на .сІЬ2), Ргатежогк II (файлы БД и электронные таблицы 
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с расширением .№2), І-о1и$ 1-2-3 (файлы с расширением .жкі, 
а для импорта файлов старших версий Іо1и$ 1-2-3 с расширением 
.ѵік* следует использовать позицию Сору гесогсіз йч>т поп-сІВАЗЕ 
Іііе из меню АррепсІ), РР5:РИЕ (файлы типа РР5, не имеющие 
расширения). Следует быть особенно внимательными при 
импорте последнего типа файлов. После ввода в сІВАЗЕ IV им 
присаиваются расширения .сІЫ, .ѵие, .Іті. 

Позиция Ехрогі меню ТооІ$ позволяет экспортировать файлы 
БД сІВАЗЕ IV с расширением .сІЫ в другие типы внешних 
файлов. После создания внешнего файла ему автоматически 
присваивается соответствующее расширение. Можно экспортиро¬ 
вать файлы БД сІВАЗЕ IV в следующие типы файлов (в скобках 
указывается расширение файла): КарісНіІе (.грсі), сІВАЗЕ II 
(.сІЬ2) - перед использованием в сІВАЗЕ II необходимо это 

расширение преобразовать в .сІЫ, Ргатежогк II (.№2), І.о1и$ 
1-2-3 (.жк$), Ѵі$іСаІс (.<Ш), РРЗгРИЕ (без расширения), 

ЗуІк-МиІІірІап (без расширения), Тех! ІіхесМепдІН 1іеІсІ$ (.1x1) 
файл типа ЗОЕ, ВІапк ОеІітіІесІ (.1x1) - текстовый файл с 

разделителями в виде пробелов (можно задавать другие виды 
разделителей). 

Позиция РОЗ Шіііііез меню ТооІ$ позволяет выполнять 
многие полезные операции при работе с файлами. После выбора 
этой позиции высвечивается таблица со списком имен файлов и 
их характеристиками, включая емкость занимаемой памяти в 
байтах (слово <РІК> обозначает имя директория), дату 
создания или последнего обновления, атрибуты файла (см. 
руководство по РОЗ) и память, занимаемую файлом на диске. 

В двух нижних строках таблицы указывается количество и 
общий объем файлов в таблице, а также количество и общий 
объем помеченных файлов. Помеченные файлы составляют 
список, с которым можно выполнять операции как с одной 
группой, например удалять, копировать и т.д. По строкам 
таблицы можно передвигаться, используя навигационные клавиши. 
Для высвечивания списка файлов директория его следует выбрать 
(установить на него курсор и нажать Епіег). Родительский 
(вышестоящий) директорий по отношению к текущему высвечи¬ 
вается выбором позиции <рагеп1>. Повторный последовательный 
выбор этой позиции приводит к корневому директорию. 

Движение по директориям легче выполнять по дереву 
директориев, которое высвечивается клавишей Р9 из любого 
места в таблице файлов. Передвижение по дереву также 
осуществляется навигационными клавишами. Высвечивание списка 
файлов Директория выполняется выбором соответствующей 
позиции. Для перехода на другой диск нужно установить курсор 
на букву текущего диска в верхней части дерева и нажать 
клавишу Епіег (высвечивается список имеющихся дисков). 
Последующий выбор диска приводит к высвечиванию дерева его 
директориев. 
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Позиция 005 Шііігіез зсгееп включает меню с опциями: 005, 
Рііе^, 5огі, Магк, Орегаііопх и Ехіі. Опция 005 позволяет 
выполнять команды 005 и устанавливать новый текущий диск и 
директорий. С помощью позиции Регіогт 005 соттапсі этой 
опции можно выполнять команды 005 непосредственно из СІВА5Е 
IV. После завершения выполнения команды 005 для перехода 
к списку файлов требуется нажать любую клавишу. 

Выбор позиции Со іо 005 приводит к переходу в 005. При 
этом высвечивается полный экран, на котором записываются 
команды 005 или программы исполнимых машинных команд. Эти 
команды и программы выполняются не выходя из СІВА5Е IV. При 
этом метки файлов для выполнения групповых операций в 
таблице, из которой осуществлен выход в 005, удаляются. Об 
этом дается специальное уведомление и предложение продол¬ 
жить выполнение (Ргосеесі) или отменить (СапсеІ) эти опера¬ 
ции. После завершения операций 005 возврат в СІВА5Е IV 
осуществляется вводом и выполнением команды ЕХІТ. 

Для установки диска и директория, которые будут использо¬ 
ваться во всех операциях по умолчанию (т.е. без явного 
указания диска и директория), используется позиция 5еі сіеіаиіі 
Огіѵе: сГігесіогу (имя диска и директорий вводятся с клавиатуры 
в высвеченное окно). Можно выбрать директорий из списка 
директориев, высвечиваемого клавишами 5НІЙ-Р1. 

Позиция Рііе* позволяет изменить диск и директорий файлов 
в таблице и высветить в ней только требуемые файлы. Смена 
диска и директория осуществляется выбором опции СЬапде 
Огіѵе: сіігесіогу. Как и для установки диска, используемого по 
умолчанию, в высвечиваемое окно нужно ввести с клавиатуры 
требуемое имя диска и директория. Имя директория можно 
выбрать из списка, высвечиваемого клавишами 5ЫЙ-Р1. Для 
высвечивания в таблице файлов используется позиция Оізріау 
Опіу, дающая возможность отобрать файлы с заданным расшире¬ 
нием или одинаковой частью имени с помощью знаков замеще¬ 
ния * и ?. Знак ? замещает одну позицию имени, а знак * - 
любое число позиций. Эту опцию можно использовать вместе с 
опцией Магк пометки групп файлов. 

Позиция 5огі служит для изменения порядка, в котором 
файлы представляются в списке. Текущий порядок показывается 
справа внизу таблицы. Может быть установлен порядок в 
соответствии с одним из перечисленных ниже способов, которые 
устанавливаются выбором следующих опций: Нате (по имени 
файлов), Ехіеп$іоп (по расширению файлов), Оаіе & Тіте (по 
дате и времени создания файла), $іге (по размеру файлов). 

Позиция Магк дает возможность помечать файлы для 
групповой обработки. Файлы остаются помеченными до выхода 
в УЦ или в 005 командой Со іо 005. Различные операции по 
пометке файлов выполняются выбором опций: Магк аІІ (пометка 
всех файлов в таблице), ІІптагк аІІ (уничтожение всех пометокѴ 
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Кеѵегхе тагкз (реверс пометок - пометка неотмеченных файлов 
и удаление пометок ранее помеченных файлов). 

Позиция Орегаііопз позволяет выполнять следующие 

операции с файлами: уничтожение, копирование, перемещение, 
переименование, просмотр, редактирование текстовых или 
программных файлов. При выполнении первых четырех операций 
высвечивается окно с позициями, позволяющими выбрать: один 
текущий файл ($іпдІе), группу отмеченных файлов (МагкесІ 
йіѳі) или все файлы в таблице (ОізрІауесІ Іііех). Если курсор 
находится на имени директория, то при выборе позиции Ёіпдіе 
все операции за исключением переименования, просмотра и 
редактирования применяются ко всем файлам директория. 

Уничтожение файла или группы помеченных файлов реали¬ 
зуется с помощью позиции Реіеіе. Перед непосредственным 
уничтожением требуется подтвердить операцию (Ргосеесі) или 
отменить ее (СапсеІ). Удалить один текущий файл можно также 
клавишей Оеі 

Опция Сору позволяет копировать помеченные файлы на 
другой диск и директорий, набираемый с клавиатуры в высвечи¬ 
ваемое окно. Если ранее уже выполнялось копирование, то 
высвечивается предыдущее назначение копирования, которое 
можно утвердить клавишей Епіег или заменить новым, набран¬ 
ным с клавиатуры или выбранным из списка директориев, 
вызванным клавишами 5НІН-Р1. Для копирования файлов с теми 
же именами, но в другой директорий в качестве имени нового 
файла (файла-мишени) можно использовать шаблон *•*. Нельзя 
копировать файл в самое себя. Копировать также можно 
клавишей Р8. При этом высвечивается окно для ввода маршрута 
по директориям и имени файла-мишени. 

Позиция Моѵе осуществляет перемещение одного или 
группы помеченных файлов на новое место. Действия по 
выполнению операции аналогичны операции Сору. Переместить 
один текущий файл можно также клавишей Р7 (высвечивается 
окно для ввода маршрута по директориям и имени файла на 
новом месте). В этом случае операция должна завершаться 
клавишами ОгІ-Епб. 

Для переименования файлов используется опция Кепате. 
Просмотр содержимого файла осуществляется опцией Уіеѵі, при 
этом нетекстовые символы не высвечиваются. Файл можно 
просматривать страницами экрана, листая их клавишей Пробел 
или без остановки, нажав клавишу Епіег. Выход из просмотра 
выполняется клавишей Е$с. 

Редактирование текстовых или программных файлов можно 
выполнить с помощью опции Есііі. 

Позиция Ргоіесі баіа служит для организации системы 
доступа в пакет СІВА5Е IV в многопользовательском режиме и 
в среде ЛВС, а также для организации разграничения доступа и 
защиты информации. К этой позиции прикрепляется довольно 


40 



сложное иерархическое меню, содержание которого описано в 
разд. 2.11. 

Позиция ЗеНіпд* меню ТооІ$ позволяет установить ряд 
параметров сІВАЗЕ IV, например форму даты и разделитель 
позиций в ней, некоторые режимы обработки файлов, форматы 
полей в файлах БД, цвета различных областей экрана, а также 
сделать другие вспомогательные назначения. При выборе этой 
позиции высвечивается меню с позициями: Орііопз, Оізріау и Ехіі. 

Позиция Орііопі дает возможность выполнить в текущем 
сеансе установку на включение (ОН) или выключение (ОРР) 
значений параметров вывода и обработки данных. Эти параметры 
определяют подачу звукового сигнала, которая осуществляется 
при определенных ситуациях, например после заполнения поля 
данных (ВеІІ), копирование данных в последующую запись из 
предыдущей (Саггу), вывод в дате четырех цифр года 
(Сепіигу), автоматический переход курсора на следующее поле 
после заполнения предыдущего (Сопіігт), порядок вывода 
месяца, дня и года в дате (Оаіе огсіег МРѴ), разделитель в 
дате - "/", или (Оаіе $ерагаіог), выводимое число 

десятичных позиций (ОесітаІ рІасе$), пропуск помеченных для 
удаления записей при обработке файла БД (Оеіеіесі), требование 
точного совпадения искомой и заданной строк при их сравнении 
в ходе поиска (Ехасі), режим исключительного пользования 
файлом в среде ЛВС (Ехсіизіѵе), высвечивание панели УЦ при 
входе в него (Іпзігисі), сдвиг позиций слева при печати 
неформатированного текста (Магдіп), ширину печатаемого поля 
типа Мето (Мето ѵѵісШі), предупреждение при перезаписи 
существующего файла ($а(е1у), вывод на экран результатов 
выполнения операций (Таік), включение отладчика программ 
(Тгар). 

Позиция (меню) Різріау позволяет установить посредством 
выбора значений 25 или 43 в опции (позиции) Різріау тосіе 
ЕСА число строк на экране монитора типа ЕСА. В этом же 
меню можно назначить цвета различных областей экрана 
посредством выбора позиций: $іапс!агсІ - АН - цвета всех 
элементов стандартных областей экрана, ИогтаІ іехі - цвет текста 
стандартной области экрана, Ме$$аде$ - цвет сообщений, Тіііез - 
цвет заголовков, ЕпЬапсесІ - АН - цвет всех элементов 
нестандартных областей экрана, НідМідНТ - цвет подсвечиваемых 
полей, Вохе$ - цвет рамок, ІпІогтаНоп - цвет информации в 
нестандартных областях экрана, РіеІсІ$ - цвет полей, РегітеІег о( 
зсгееп - цвет периметра экрана. 

Позиция Ехіі меню сервисных функций выполняет выход на 
панель УЦ. 

В качестве примера работы с меню сервисных функций 
покажем более подробно, как установить требуемый маршрут по 
директориям, который будет нужен для просмотра учебного 
примера, европейский формат даты (типа ДД/ММ/ГГ, где 
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ДД-день, ММ-номер месяца, ГГ-год), а также как копировать, 
Удалять, перемещать и переименовывать файлы. В предыдущем 
разделе описывалась операция копирования с помощью пакета 
ІЧогіоп Соттапсіег, но для этого нужно выйти из сІВАЗЕ IV в 
□05. Здесь же будет описано, как выполнять эти операции 
средствами сІВАЗЕ IV. 

Для высвечивания файлов учебного примера на панели УЦ 
после входа в сІВАЗЕ IV активизируйте меню сервисных функций 
клавишей РІО, выберите подменю (позицию) РОЗ ШіІЖе* меню 
ТооІ$. Затем активизируйте это подменю клавишей РІО и 
выберите потом позицию $еі сіеіаиіі 4гіѵе:сІігес1огу меню 
(позиции) РОЗ. В результате в окне высветится текущий 
директорий, например, Р:\РВАЗЕІѴ. Установите в маршруте 
поддиректорий РКІМЕК, для чего добавьте наклонную черту 
влево и слово РКІМЕ& (Р:\РВАЗЕІѴ\РКІМЕК) и нажмите 
клавишу Епіег. Для выхода в УЦ нужно активизировать меню 
клавишей РІО, перейти навигационной клавишей "Вправо" на 
позицию Ехіі и затем выбрать позицию Ехіі іо СопігоІ Сепіег. 
Можно использовать другой способ выхода, нажав клавишу Е$с 
и затем подтвердить выход нажатием буквы "V" на клавиатуре 
или выбором позиции "ѴЕЗ" в высветившемся меню. После этого 
на панели УЦ в окнах высветятся имена всех учебных файлов. 
Заметим, что при установке маршрута Р:\ОВАЗЕІѴ\РКІМЕК 
предполагалось, что поддиректорий РКІМЕК директория РВАЗЕІѴ 
уже создан (например, средствами пакета ІЧогіоп Соттапсіег). 
Покажем теперь, как создать этот поддиректорий средствами 
сІВАЗЕ IV. В меню ТооІ$ сервисных функций есть позиция, 
которая позволяет выполнять команды ЭОЗ не выходя из пакета 
сІВАЗЕ IV. Для создания директория используется команда тксііг 
или сокращенно тсі. Чтобы создать поддиректорий РКІМЕК в 
директории РВАЗЕІѴ, нужно, находясь в директории 

Р:\РВА5ЕІѴ, выбрать позицию Регіогт 00$ соттапсі подменю 
второго уровня РОЗ, которое вызывается после выбора подменю 
первого уровня РОЗ иііііііез меню ТооІ$. Заметим, что для 
активизации подменю РОЗ надо нажать клавишу РІО. После этого 
высветится предложение ввести команду РОЗ. Введите с 
клавиатуры т<1 ргітег и нажмите Епіег. Поддиректорий создан. 
Ниже будет описано, как средствами сІВАЗЕ IV копировать 
файлы. 

Если Вы хотите решаемые примеры записывать на учебную 
дискету в директорий, где находятся учебные файлы, то после 
выбора позиции Зеі сіеіаиіі 4гіѵе: гіігесіогу меню РОЗ укажите 
А:\РКІМЕК и нажмите клавишу Епіег. Напомним, что в этом 
случае при решении примеров надо файлам давать имена, не 
совпадающие с именами на учебной дискете, иначе последние 
будут заменены Вашими примерами. Это же относится и к 
записи решаемых Вами примеров на жесткий диск в директорий 
учебных файлов. 
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Если Вы хотите записывать решаемые примеры не на 
жесткий диск или на учебную дискету, а на свою дискету, то 
после выбора позиции $еі сіеіаиіі сігіѵе: сіігесіогу меню 005 
сервисных функций укажите А:\ и нажмите клавишу Епіег. 

Для установки европейского формата даты выберите 
позицию Зеіііпдз меню ТооІ$, затем в высветившемся 
вертикальном меню, прикрепленном к позиции горизонтального 
меню Орііопз, установите курсор на позицию йаіе огсіег и 
клавишей Пробел выберите европейский формат даты - ОМУ. 
Перейдите в позицию Ехіі горизонтального меню и нажмите 
клавишу Епіег. Установку формата даты можно также выполнить 
в командном режиме. Выход в командный режим осуществляется 
выбором позиции Ехіі* іо сіоі рготрі меню Ехіі сервисных 
функций, которое активизируется клавишей РІО. В командном 
режиме нужно набрать с клавиатуры команду $ЕТ ОЛТЕ СЕКМАЫ 
и нажать клавишу Епіег. Выход в УЦ из командного режима 
осуществляется набором с клавиатуры команды А55І5Т или 
нажатием клавиши Р2. 

Операции по копированию, удалению, перемещению и 
переименованию файлов выполняются с помощью позиции 
Орегаііопз подменю 005 иііііііез меню Тооіз. После выбора 
подменю 005 иііііііез высвечивается окно с именами файлов 
диска и директория, в котором установлен пакет сІВАЗЕ IV. В 
этом окне высвечиваются файлы, с которыми можно выполнять 
предусмотренные операции. Диск и директорий этих файлов 
можно установить, выбрав сначала позицию РіІез подменю 005 
иііііііез, а затем в высветившемся меню позицию СКапде сігіѵе: 
сіігесіогу. После выбора этой позиции курсор устанавливается в 
окно, где уже стоит имя диска и директория (директория, из 
которого запущен пакет сІВАЗЕ IV или диска и директория 
предыдущей установки). После ввода имени нового диска и 
(или) директория нужно нажать клавишу Епіег. 

В этом меню имеется вторая позиция Оізріау опіу, которая 
позволяет высветить в окне только те файлы, которые 
соответствуют задаваемому шаблону. Например, можно высветить 
только файлы БД или только файлы запросов. В первом случае 
в качестве шаблона нужно ввести *.сІЫ, а во втором случае 
*.дЬе. Если требуется высветить только файлы БД, начинающиеся 
с буквы Р, то надо ввести шаблон Р*.сІЫ. Напомним, что знак * 
означает замещение любого количества символов. Кроме этого 
знака для замещения символов имени и расширения файла 
можно использовать один или несколько знаков ?, каждый из 
которых замещает только один символ. Например, шаблон 
МСШ.яЬе позволяет высветить файлы запросов, имена которых 
начинаются с букв МО и всего содержат четыре символа. После 
ввода шаблона также надо нажать клавишу Епіег. 

Заметим, что директорий, файлы которого высвечиваются в 
окне, и директорий, в который записываются файлы по 
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умолчанию, т.е. без специального указания диска и маршрута 
(часто говорят, что это директорий, установленный по 
умолчанию), - это в принципе разные директории. 

Первый используется только для высвечивания в окне 
файлов, с которыми можно выполнять операции, а второй - это 
директорий, с которым по умолчанию, выполняются операции: 
считываются или записываются файлы. После входа в сІВАЗЕ IV 
по умолчанию автоматически устанавливается директорий, из 
которого он вызван. Как уже упоминалось, смена диска и 
директория, установленного по умолчанию, осуществляется с 
помощью позиции Зеі сіеіаиіі сІгіѵе:сІігесіогу меню (позиции) 
йОЗ подменю РОЗ ШіІЖез меню ТооІ$. 

Можно, например, выполнять операции с каким-то 
директорием жесткого диска, затем прервать эту работу и 
выполнить операции по копированию на жесткий диск файлов с 
дискеты или, наоборот, скопировать файлы с жесткого диска на 
дискету. Для этого надо установить имя и директорий 
копируемых файлов (например, для дискеты А:\РКІМЕК, а для 
жесткого диска С:\РВАЗЕІѴ\РЛІМЕК) с помощью позиции СЬапде 
сігіѵе: сіігесіогу подменю ЕіІе$, которое вызывается из подменю 
РОЗ иііііііез меню Тооіз. (Напомним, что имена дисков, 
директориев и файлов можно вводить как строчными, так и 
прописными латинскими буквами.) После завершения операции 
копирования можно продолжить работу с диском и директорием, 
установленным ранее по умолчанию, который остается без 
изменения. 

После того как установлен требуемый диск и директорий, с 
файлами которого нужно выполнить операции, следует выбрать 
позицию Орегаііопз подменю РОЗ иііііііез меню ТооІ$. Напомним, 
что после выбора подменю РОЗ иііІіііе$ и высвечивания окна с 
файлами, меню следующего уровня находится в неактивном 
состоянии. Для активизации меню нужно нажать клавишу РІО. 
После выбора позиции Орегаііоп$ высвечивается меню, в котором 
перечислены операции: удалить (Реіеіе), копировать (Сору), 
переместить (Моѵе), переименовать (Кепате), просмотреть 
(Ѵіеж) и редактировать. (Есііі). Если нужно выполнить операцию 
с одним файлом, достаточно установить на его имя курсор. 
Перед выполнением операций копирования, удаления или 
перемещения нескольких файлов их имена надо пометить, что 
эквивалентно подсвечиванию файлов при использовании пакета 
Иогіоп Соттапсіег. Пометка файлов по-одному выполняется 
клавишей Епіег после установки курсора на имя файла. Знаком 
пометки служит треугольник, помещаемый слева от имени файла. 

Все файлы директория можно пометить с помощью позиции 
Магк подменю РОЗ ігііііііез. После выбора этой позиции 
высвечивается меню с позициями: Магк аІІ - пометить все 
файлы, ІІптагк аІІ - погасить пометки всех файлов и Кеѵегз - 
погасить имеющиеся пометки и пометить ранее не помеченные 
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файлы. Если требуется выполнить операцию со всеми 
высвеченными файлами, то их можно не помечать. После того, 
как файлы помечены или, если операция выполняется с одним 
файлом, на его имя установлен курсор, можно выполнять 
требуемые операции. Для этого следует выбрать требуемую 
операцию из меню, высвечиваемого после выбора позиции 
Орегаііопз. После этого высвечивается меню с тремя позициями 
$іпдІе Рііе, Магкесі Рііех и 0і$рІауес1 Рііех, одну из которых нужно 
выбрать в соответствии с тем, как определены файлы, с 
которыми требуется выполнить эти операции. Выбор первой 
позиции предполагает выполнение операции с одним файлом, на 
который установлен курсор. Выбор второй позиции предполагает 
выполнение операции с помеченными файлами, а выбор третьей 
предполагает выполнение операции со всеми высвеченными в 
окне файлами. 

При выполнении операции по удалению файлов высвечива¬ 
ется сообщение, что выполняется эта операция и меню с двумя 
позициями, в котором для подтверждения удаления нужно 
выбрать позицию РгосеесІ, а для отмены удаления позицию 
СапсеІ. Для операций копирования и перемещения нужно ввести 
с клавиатуры имя диска и директорий, куда копируются или 
перемещаются файлы, и нажать Епіег, затем можно изменить 
старое имя файла, которое высвечивается в окне, на новое и 
нажать клавиши СігІ-ЕпсІ для завершения операции. При переиме¬ 
новании нужно ввести новое имя. Просмотр и редактирование 
файлов выполняется только по-одному. Заметим, что эти 
операции можно использовать только с текстовыми файлами, 
причем в неадаптированной версии сІВАЗЕ IV при просмотре 
файла кириллица выводится искаженно. 


2.4. СОЗДАНИЕ ФАЙЛОВ БАЗ ДАННЫХ И ВВОД ЗАПИСЕЙ 

Рассмотрим теперь, как создать структуру файла БД. Для 
этого надо выбрать позицию <сгеаіе> окна Раіа на панели УЦ. 
Вспомним, что мы условились понимать под выбором позиции: 
установить курсор на нужной позиции и нажать клавишу Епіег. 
На экране появится таблица, состоящая из шести колонок с 
именами: порядковый номер поля (Иит), имя поля (РіеІсІ 
Ыате), тип поля (РіеІсІ Туре), ширина поля (\ѴісІіЬ), количество 
дробных десятичных знаков числа (Рее), признак индексирования 
поля (Іпсіех). Каждая строка этой таблицы содержит информа¬ 
цию об одном поле записи файла БД. Последовательность 
номеров полей соответствует их расположению в записи файла 
БД. До тех пор, пока структура файла БД не записана в каталог, 
ее можно свободно изменять посредством передвижения курсора 
и изменения описаний полей данных клавишами ввода и 
удаления символов. Имя поля может включать до 10 бук- 
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венно-цифровых символов, но должно начинаться обязательно с 
буквы. Тип поля (символьный - СЬагасіег, числовой с фиксиро¬ 
ванной точкой - Ыитегіс, числовой с плавающей точкой - РІоаі, 
текстовый - Мето, логический - І.одісаІ и типа даты - йаіе) 
можно выбрать клавишей Пробел или набрать непосредственно 
с клавиатуры. Ширина поля для символьных полей ограничена 
254 позициями, а для числовых полей 20 позициями (включая 
знак числа, десятичную точку и дробные десятичные знаки). 
Ширина полей типа даты и логических полей фиксирована и 
вводится в таблицу автоматически. Данные из текстового поля 
Мето (шириной до 32767 символов) хранятся не в самом файле 
БД, а в связанном с ним специальном файле. В таблицу 
описания полей при создании поля Мето автоматически вводится 
фиксированная ширина ссылки (10 позиций) на этот файл. 
Завершается ввод информации по одному полю указанием 
признака для создания индекса по этому полю (V - индекс 
создается, N - не создается). 

Для решения задачи учета работы автотранспортных средств 
сформируем структуры четырех файлов БД. В учебных примерах 
им присвоены имена ЕШ1-ЕЮ4. Чтобы не было совпадения имен 
файлов при работе с учебной дискетой, условимся в дальнейшем 
давать имена создаваемым Вами файлам те же, что и в учебных 
примерах, но с буквой М впереди. Тогда для файлов БД эти 
имена будут МЕШ1-МВ04. Заметим, что имена полей нужно 
вводить в таблицу структуры БД с первой позиции. Движение по 
полям таблицы вправо осуществляется клавишей ТаЬ, а влево 
клавишами §МН-ТаЬ. (Здесь и далее запись английских имен 
клавиш через тире означает, что первую клавишу нужно держать 
нажатой, а вторую нажимать после для вызова действия.) 
Сначала создадим структуру файла БД МВйІ (табл. 2.3). 

После того как введено описание для всех полей файла БД, 
созданную структуру следует сохранить на диске. Для этого надо 
сначала клавишей МО вызвать меню экрана создания/модифика¬ 
ции структуры БД и затем выбрать позицию $аѵе ІЬІ$ сІаіаЬазе 
Іііе зігисіиге (сохранить структуру файла БД) меню Ьауоиі 


Таблица 2.3. Структура файла МКЮ1 


Ишл 

Иеігі Иате 

Р і е 1 <3 Туре 

ѴісКН 

Рее 

Іпгіех 

1 

№М 

Мишегіс 

4 

0 

V 

2 

РАМ 

СИагасТег 

15 


У 

3 

ММ 

СИагасІег 

15 


N 

4 

ОТС 

СИагасІег 

15 


N 

5 

0 К 

йаТе 

8 


N 

6 

3 К 

Иишегіс 

2 

0 

N 

7 

КАТ 

- СЬагас^ег 

9 


N 

8 

лито 

Мето 

10 


N 

9 

N 2 

СИагасТег 

9 


V 
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В ответ на запрос $аѵе а$: вводится имя диска, маршрут по 
директориям и в конце имя файла БД по форме 0:\0ВА$ЕІѴ\ 
РКІМЕК\МІШ1. Сохранение структуры созданной БД можно также 
выполнить выбором позиции $аѵе сЬапдез апсі ехіі меню Ехіі с 
последующим выходом в УЦ. 

Для удобства работы в УЦ с созданным файлом БД можно 
ввести его словесное описание, выбрав позицию Есііі сіаіаЬазе 
сіезсгіргіоп (редактировать описание файла БД) этого же меню. 
Напомним, что меню всегда вызывается клавишей РІО. Введем 
описание файла ВОІ: " Данные о водителях". Можно также 
распечатать созданную структуру, выбрав позицию РгіпІ сІа1аЬа$е 
хітисіиге. 

Выход из экрана создания/модификации файлов БД без 
сохранения осуществляется выбором позиции АЬапсІоп сЬапдез 
апсі ехіі меню Ехіі 

Выход без сохранения также можно выполнить клавишей Е$с 
с последующим подтверждением "У". 

Для закрепления описанных действий по созданию структуры 
БД самостоятельно создайте структуры файлов БД с именами 
МЕШ2, МВРЗ, МЕЮ4, например, так, как показано в табл. 2.4-2.6. 

Если после создания структуры файла БД обнаружены 
какие-либо ошибки, то структуру можно изменить (модифици¬ 
ровать). Напомним, что перед выполнением любых действий с 
файлом БД его следует сначала открыть, т.е. выбрать имя файла 
в окне йаіа на панели УЦ. Вспомним, что значит выбрать имя 
файла: установить курсор на его имя в окне и нажать Епіег. 
После этого появится горизонтальное меню, в котором нужно 
выбрать позицию Ц$е Іііе (открыть файл). Если требуется файл 
модифицировать, то после его выбора в окне йаіа на панели УЦ, 
затем в высветившемся окне нужно выбрать позицию Мосіііу 
зігисіиге/огсіег (изменить структуру/порядок) горизонтального 
меню. 

Модификация осуществляется так же, как и создание новой 
структуры файла БД. При модификации можно удалять и вводить 
новые поля и изменять их размеры и тип. Перед вводом нового 
поля в требуемое место таблицы нужно нажать клавиши СІгІ-И, 
в результате чего в этом месте таблицы появится пустая строка, 
в которую можно вводить данные. Удаление любой строки 
таблицы структуры файла БД выполняется клавишами СігІ-ІР. 


Таблица 2.4. Структура файла МВР2 


Иит 

Ріеісі Иате 

Ріеісі Туре 

МісЙН 

йес 

Іпсіех 

1 

N 1 

СИагасІег 

9 


У 

2 

503 

СЬагасІег 

12 


N 

3 

МАР 

СИагасіег 

10 


У 

4 

6 N 

СНагасІег 

12 


N 
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Таблица 2.5. Структура файла МІШЗ 


Ишл 

Ріеісі Иаше 

Ріеісі Туре 

ѴісЛ:Н 

дес 

Іпсіех 

1 

N 6 

СИагас^ег 

20 


N 

2 

0 Р 

СИагасЪег 

15 


N 

3 

й V 

Ра іе 

8 


N 

4 

К 0 

СИагасІег 

15 


N 

5 

й Р 

Оаіе 

8 


N 

і б 

РАЗ 

Мишегіс 

4 

0 

N 

7 

ѴЕЗ 

Мишегіс 

4 

1 

N 

8 

ѴРМ 

Мишегіс 

3 

0 

N 

9 

Р6Р 

Мишегіс 

6 

2 

N 

10 

N 1 

СИагасІег 

9 


V 


Таблица 2.6. Структура 

файла 

МЕШ4 

Иит 

Ріеісі Иаше 

Ріеісі Туре 

ѴісКН 

Оес 

Іпсіех 

1 

МАР 

СЬагасЪег 

10 


У 

2 

$КР 

Мишегіс 

3 

0 

N 

3 

6Р2 

Митег іс 

2 

0 

N 

4 

. 

РЗХ 

Мишегіс 

2 

0 

N 


Следует только учесть, что при изменении размера полей 
в меньшую сторону данные могут быть обрезаны, а при 
изменении типа полностью потеряны. Нужно отметить также, 
что при модификации нельзя изменить порядок расположения 
полей. Это можно сделать другим способом, например, скопиро¬ 
вав этот файл в файл с другим именем и такой же структурой, 
но с другим расположением полей. 

Продолжим обзор меню окна йаіа панели УЦ. Кроме меню 
(позиции) І.ауоиі в состав основного (горизонтального) меню, 
рассмотренного выше, входит еще меню (позиция) Огдапіхе, 
предназначенное для создания индексных файлов, а также 
некоторых других операций с файлами БД, меню (позиция) 
АррепсІ - для выполнения операций по добавлению записей в 
файл БД, меню (позиция) Со То - для передвижения по 
записям файла БД и меню (позиция) Ехіі - для выхода из 
меню. 

Как уже отмечалось, индексные файлы создаются для более 
быстрого поиска данных и вывода записей в определенном 
порядке без физической сортировки файла, при которой 
создается новый файл БД. Для этого требуется довольно много 
времени и значительная емкость памяти на диске, равная 
удвоенному объему исходного файла. При использовании 
индексов создается сравнительно небольшой индексный файл, 
который используется многократно в процессе поиска или вывода 
данных из файла БД на экран или печать. Перед поиском 
необходимо этот файл активизировать - открыть и установить 
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главный (управляющий) индекс, который и будет обеспечивать 
операции поиска и вывода данных. 

Как уже упоминалось, в сІВАЗЕ IV все индексы сводятся в 
один множественный индексный файл типа .тсіх (иногда их 
называют указателями индексов). Индексы могут строиться по 
отдельным полям (простые) или комбинациям полей (слож¬ 
ные). Всего можно создать до 47 указателей индексов в одном 
множественном индексном файле. 

Простые индексы создаются автоматически после окончания 
разработки структуры файла БД (при выборе V в колонке Іпсіех 
таблицы структуры файла). Образованный этим способом 
множественный индексный файл называется связанным, так как 
он создается автоматически и ему присваивается имя файла БД. 
При формировании сложных индексов (указателей индексов) 
создается множественный индексный файл, которому необходимо 
присвоить уникальное имя. Таких множественных индексных 
файлов можно создать до 10 на один файл БД. 

При формировании структур файлов БД ЕШ1, ІШ2, ЕШЗ, В04 
были созданы множественные индексные файлы: ЕШІ.тсІх, 
содержащий индексы полей ИОМ, РАМ, И_2; В02.тсІх - с 
индексами полей Ы_2, МАК; ЕШЗтсІх - с индексом поля И__2; 
В04.ѴПСІХ - с индексом поля МАК. 

Для совместимости с сІВАЗЕ N1+ в пакете сІВАЗЕ IV 
оставлена возможность создавать и использовать индексные 
файлы типа .псіх. В текущий момент управляющим может быть 
только один индексный файл или указатель индекса в множест¬ 
венном индексном файле (главный индекс). Меню Огдапіге 
предназначено для того, чтобы создавать и изменять сложные 
индексы, использовать индексы типа .псіх, активизировать индексы 
и выполнять другие операции, связанные с индексными файлами, 
например, удалять ненужные индексы, а также сортировать файл 
БД, уничтожать помеченные для удаления записи и другие 
операции. 

Выше описывался способ автоматического создание индекса 
в ходе формирования структуры файла БД. Кроме этого способа 
можно создать индекс с помощью позиции Сгеаіе пе^ іпсіех 
меню Огдапіхе. Обычно этот способ используется для создания 
сложных индексов, которые нельзя построить первым способом. 
После выбора этой позиции высвечивается окно с позициями для 
присвоения имени этому индексу (Иате оі іпсіех), создания 
выражения, определяющего сложный индекс (Іпсіех ехрге5$іоп), 
определения порядка индексирования по возрастанию или 
убыванию (Огсіег о! іпсіех). Имя индекса формируется по 
правилам для имен файлов: до 10 буквенно-цифровых символов, 
начиная с буквы. Выражение для сложного индекса состоит из 
комбинации полей с операторами и функциями, разрешенными 
для этих полей. Например, для символьных полей разрешена 
операция сцепления и сложный индекс может состоять из 
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последовательности имен полей, соединенных знаком " +" 
(знак сцепления полей). Имена полей можно набрать с 
клавиатуры или выбрать из списка, высвечиваемого, клавишами 
5НІН-Р1. Порядок индексирования определяется выбором клави¬ 
шей Пробел слова А$с для индексирования по возрастанию и 
0е5С - по убыванию. Если несколько записей имеют одно и то 
же значение индексного выражения, то для вывода (на печать 
или экран) только одной (первой) такой записи используется 
позиция Ьізріау іігзі сіиріісаіе кеу опіу. После ввода всех 
необходимых данных в позиции окна их следует сохранить 
(записать на диск) клавишами СІгІ-ЕпсІ. 

Для изменения уже имеющихся индексов применяется 
позиция МосІНу ехізііпд іпсіех, а для установки главного 
индекса - позиция Огсіег гесогсЬ Ьу іпсіех. Важным преимущест¬ 
вом множественного индексного файла является то, что при 
установке главного индекса не нужно открывать новый индексный 
файл. В случае использования файла типа .псіх его необходимо 
предварительно открыть, что занимает определенное время. Эта 
операция выполняется выбором позиции Асііѵаіе .псіх іпсіех ЯІе. 
Для включения в текущий каталог файла типа .псіх, находящегося 
в текущем директории (при частом употреблении), используется 
позиция Іпсіисіе .п 6х іпсіех ЯІе. 

При модификации задачи некоторые индексы могут оказаться 
ненужными. Поскольку для больших файлов они занимают много 
памяти на диске, целесообразно их удалить. Для этого использу¬ 
ется позиция Кетоѵе ипжапіесі Тад. 

Созданный файл можно физически отсортировать по 
заданным полям в возрастающем или убывающем порядке с 
помощью позиции $огі сіаіаЬазе оп Ііеісі Іі$1 Для того чтобы 
отсортировать файл БД, необходимо сначала его открыть 
(выбрать на панели УЦ в окне Оаіа). После этого клавишами 
5ЫЙ-Р2 нужно перейти в меню Огдапіге и выбрать позицию $огі 
сІаіаЬазе оп Ііеісі Іі$1. В результате высветится таблица ввода 
данных для сортировки с двумя графами: РіеІсІ огсіег (имена 
сортируемых полей) и Туре о! $ог! (тип сортировки). 

В первую графу заносятся имена нескольких полей (или 
одно поле) в том порядке, который определяет последователь¬ 
ность сортировки. Следует отметить, что сортировка может 
выполняться только по индексированным полям. Имена полей 
вводятся с клавиатуры или из списка, высвечиваемого клавишами 
5НІН-Р1. 

Во вторую графу вводится тип сортировки: А$сеп<1іпд - по 
возрастанию, Оезсепсііпд - по убыванию, А$сепсііпд Оісііопагу - 
по возрастанию без различия прописных и строчных букв, 
Резсепсііпд РісЯопагу - аналогично по убыванию. Заданные 
значения надо сохранить клавишами СІтІ-ЕпсІ, затем ввести имя 
отсортированного файла и нажать клавишу Епіег для выполнения 
сортировки. 
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Это же меню позволяет уничтожить все имеющиеся пометки 
для удаления записей в файле БД (Цптагк аІІ гесогсіз), а также 
помеченные для удаления записи (Ега$е тагкесі гесогсі:). 

Меню ЛррепсІ дает возможность добавлять в созданный 
файл БД записи с клавиатуры (Епіег гесогсЬ (гот кеуЬоагсІ), из 
другого файла БД (ЛррепсІ гесогсіз (гот СІВА5Е (ііе) и из 
внешнего (не-сІВА5Е) файла (Сору гесогсіз (гот поп-сІВА$Е (Не). 
При добавлении с клавиатуры открывается стандартная экранная 
форма Вготе или Есііі, описание которых дается ниже. В случае 
добавления записей из другого файла имя этого файла нужно 
выбрать из списка имен файлов БД в текущем или других 
директориях в высвечиваемом на экране списке. После выбора 
имени файла выполняется добавление записей из этого файла 

БД. 

При добавлении записей из внешних файлов высвечивается 
таблица с именами типов внешних файлов (в скобках указывает¬ 
ся расширение файла): КарісНіІе (.грсі), сІВА$Е II (.сІЬ2) - перед 

использованием в сІВАЗЕ 11 необходимо это расширение 
преобразовать в .с!Ь(, Ргатежогк II (.(ж2), І.о1и$ 1-2-3 (.жк$), 
ѴшСаІс (.сіі(), РР$:РИЕ (без расширения), $уІк-МиІ1ірІап (без 
расширения), Тех! (іхесМепдіЬ (іеісіз (.1x1) - текстовой файл типа 

5ЭР, ВІапк Ьеіітііесі (.М) - текстовой файл с разделителями в 

виде пробелов (можно задавать другие виды разделителей). 

После выбора требуемого типа файла высвечивается список 
директориев и имен файлов этого типа на текущем диске. Для 
того чтобы перейти в директорий высшего уровня, нужно 
выбрать позицию <рагеп!> этого списка. Другие директории 
также раскрываются их выбором. Если требуется перейти на 
другой диск, то курсор надо установить на позицию с именем 
текущего диска и нажать клавишу Епіег. После выбора имени 
внешнего файла выполняется добавление его записей в конец 
файла БД сІВАЗЕ IV. При добавлении записей следует учитывать 
соответствие длины и типа полей внешнего и принимающего 
файлов. При несоответствии данные могут усекаться или 
восприниматься не в том виде, как это предполагалось. 

Ввод новых и обновление существующих записей, как и их 
добавление, выполняется в одних и тех же стандартных экранных 
формах Вгом/зе и Есііі. Напомним, что предварительно нужно 
файл БД открыть. Факт открытия файла отмечается на панели УЦ 
тем, что его имя перемещается выше черты под слово 
<сгеа!е>. Выход на экраны ввода и обновления данных можно 
выполнить несколькими способами. Находясь на экране разработ¬ 
ки структуры файла БД, после ее окончания можно сразу 
перейти к вводу данных посредством выбора позиции Епіег 
гесогсіз (гот кеуЬоагсІ меню ЛррепсІ. 

Кроме того, вход в стандартные экранные формы можно 
выполнить из УЦ. Для этого после установки курсора на имя 
файла в окне Раіа нужно нажать клавишу Епіег и затем выбрать 
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позицию Оізріау сіаіа или более коротким способом - нажать 
клавишу Р2. После этого высветится одна из стандартных 
экранных форм: Вгож$е или Есііі (в зависимости от того, какая 
из форм была на экране в предыдущем сеансе обновления, 
переключение на альтернативную форму осуществляется 
клавишей Р2). Следует отметить, что такое переключение 
возможно только, если файл не пустой. Поэтому сначала надо 
ввести данные хотя бы в одну запись в высвеченной форме, а 
затем установить желаемую форму. 

В форме Вготе данные высвечиваются в табличном виде 
(строка таблицы - запись файла), при этом не все поля могут 
одновременно разместиться на экране. Для просмотра скрытых 
полей и ввода в них информации следует использовать навигаци¬ 
онные клавиши ТаЬ и $ЬіН-ТаЬ (для движения по полям 
соответственно в прямом и обратном направлениях), клавиши 
Ноте и ЕпсІ для быстрого передвижения в левую и правую 
части таблицы, клавиши со стрелками Вправо и Влево - для 
перемещения внутри полей, клавиши со стрелкам Вверх, Вниз и 
РдІІр, Рдйп - для перехода по строкам и страницам таблицы. 
Информация, вводимая в поля файла БД, сначала записывается 
в промежуточный буфер, поэтому до момента перенесения ее 
на диск еще можно восстановить старые данные. 

Перенос информации на диск осуществляется автоматически 
после перехода к следующей записи или после выхода из 
операции ввода. Следует отметить, что данные последней 
введенной записи не сохраняются на диске, если выход из 
операции ввода осуществляется с помощью клавиши Ехс или 
другим некорректным способом. Во избежание потери данных 
выход из операции ввода следует выполнять только с помощью 
позиции Ехіі меню Ехіі или нажатием клавиш СігІ-ЕпсІ. 

В формах Вгомгсе и Есііі все поля, за исключением поля типа 
Мето, представлены явно, и в них можно непосредственно 
вводить или обновлять данные. Поле типа Мето представляется 
на экране в виде маркера - слова Мето. Если это слово 
записано строчными буквами, то это поле не заполнено инфор¬ 
мацией, если прописными, то информация в этом поле уже есть. 
Раскрытие поля для ввода или просмотра данных в нем выполня¬ 
ется клавишами СігІ-Ноте или клавишей Р9, а закрытие - 
клавишами СігІ-ЕпсІ или Р9. 

В форме Есііі поля одной записи размещаются одно под 
другим на одной или нескольких страницах экрана (в зависимос¬ 
ти от количества полей). Раскрытие последующих страниц 
выполняется клавишей РдРп. Передвижение по полям и записям 
осуществляется так же, как и в форме Вготе. 

Экранные формы Вгож$е и Есііі имеют свои меню для 
выполнения многих операций при вводе и обновлении данных 
файла БД. Эти операции можно разбить на четыре группы, 
которые имеют свои меню: операции, обеспечивающие работу 
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с записями файла БД (Кесогсіз), с полями записи (Ріеіск 
только для экранной формы Вготе), передвижение по файлу 
БД, поиск в нем данных (Со То) и выход из меню экранной 
формы (Ехіі). Содержание позиций этих меню приводится ниже. 

Следует отметить, что в современных СУБД, включая сіВАЗЕ 
IV, с целью защиты от неосмотрительных действий отсутствуют 
непосредственные команды для удаления записей. Вместо 
прямого удаления используется предварительная пометка 
(маркировка) записи на удаление. Собственно удаление группы 
помеченных записей выполняется отдельно с помощью специаль¬ 
ной команды. Пометку текущей записи можно осуществить 
клавишами СігІ-ІІ или с помощью позиции Магк гесогсі Іог 
сіеіеііоп меню КесогсІ$ экранной формы. Помеченная для 
удаления запись отмечается индикатором йеі, который высвечива¬ 
ется в правой части строки состояния, находящейся в нижней 
части экрана. Вместо удаления записи рекомендуется использо¬ 
вать позиции меню экранных форм Вгоѵѵ$е и Е 6\і для удаления 
содержимого (заполнения пробелами) целой записи (позиция 
ВІапк гесогсі меню Кесог<1$) или отдельных полей (позиция ВІапк 
(іеісі меню Ріеісіх - только для формы Вгожзе). Кроме этого, 
можно использовать клавиши СігІ-Ѵ для удаления текста поля, 
расположенного вправо от текущей позиции. 

Собственно удаление помеченных записей выполняется в 
экране создания/модификации структуры файла БД (вход в этот 
экран осуществляется из УЦ установкой курсора на имя файла 
БД в окне Оаіа и последующим нажатием клавиш 5НІК-Р2) 
выбором позиции Егазе тагкесі гесогсі 5 меню Огдапіхе. Напом¬ 
ним, что горизонтальное меню активизируется клавишей РІО. 
После этого навигационными клавишами нужно перейти на 
позицию Огдапіхе и нажать клавишу Епіег, в результате чего 
раскроется прикрепленное вертикальное меню, в котором 
выбирается нужная позиция. 

Вообще помеченные для удаления записи часто не требуется 
удалять. Пометка записей позволяет временно скрыть их - 
сделать невидимыми для поиска и отбора данных. После того 
как надобность в этом отпадет, помеченные записи можно 
размаркировать с помощью позиции ІІптагк аІІ гесогсі $ меню 
Огдапіхе в экране создания/модификации структуры файла БД. 
Размаркировка текущей записи выполняется в форме Есііі или 
Вготе нажатием клавиш СІтІ-іі или выбором позиции СІеаг 
сіеіеііоп ѵпагк меню КесогсІ$. 

Для предотвращения потерь информации предусм 9 трена 
команда восстановления содержимого всей записи после 
выполнения изменений (позиция ІІпсІо сЬапде іо гесогсі). 
Добавление новой записи можно осуществить двумя способами: 
если последняя запись является текущей, то навигационной 
клавишей Вниз (внизу экрана высвечивается сообщение АсИ пеѵѵ 
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гесогсі; ? (Ѵ/Ы) - ответить У). Если текущая запись не послед¬ 

няя, то выбором позиции АсісІ пеж гесогсі; меню КесогсІ;. 

В форме Вгож;е можно зафиксировать ряд полей на экране 
слева при передвижении курсора вправо (позиция І.оск (іеісі; оп 
ІеЙ меню Ріеісі;), очистить поле - ввести пробелы (позиция 
ВІапк ІіеісІ меню РіеІсІ;), осуществить захват записи при работе 
в среде ЛВС (і-оск гесогсі), сделать выбранное поле доступным 
для редактирования, а остальные закрыть для обновления 
(позиция Ргеехе ІіеісІ меню РіеІсІ;), изменить размер колонки 
высвечиваемого поля на экране (позиция $іхе ІіеісІ меню РіеІсІ;). 

Для передвижения по записям файла БД и поиска данных 
в формах Вгоѵѵ;е и Есііі используется меню Со То, которое 
включает следующие позиции: переход к первой записи (Тор 
гесогсі), к последней записи этого файла (І.а;І гесогсі), к записи 
по номеру (КесогсІ питЬег), пропуск N записей ($кір) ( + N 
- вперед, -И - назад), поиск с использованием индекса поля 
(Іпсіех кеу ;еагсЬ), поиск вперед (Рогѵѵагсі ;еагсН), поиск назад 
(ВаскжагсІ ;еагсЬ), установка требования различать (Ѵе;) или не 
различать (Ио) при поиске прописные и строчные буквы (МаІсН 
сарііаіігаііоп). 

При выходе из меню экранной формы Вготе или Есііі с 
помощью меню Ехіі можно передать управление на панель УЦ 
(позиция Ехіі) или в меню разработки запросов на отбор 
данных (позиция Тгап;(ег Іо яиегу 4е;ідпе). 

Проиллюстрируем, как ввести данные в файл БД. В качестве 
упражнения введите в файлы МВР1, МЕЮ2, МВйЗ и МЕШ4 
данные, приведенные в табл. 2.7-2.10. Заметим, что данные в 
поле КАТ (категория водительских прав) введены латинскими 
буквами. 

Первоначальный ввод данных представляет собой важный 
этап при создании БД. Обычно при этом требуется ввести 
большой объем информации. Поскольку БД чаще всего составля¬ 
ет систему связанных файлов, то часть информации неизбежно 
повторяется. Для того, чтобы уменьшить объем первоначально 
вводимых данных, нужно продумать последовательность этапов 
ввода и использовать предоставляемые УЦ возможности по 
автоматизации некоторых Процессов. В нашей задаче объем 
первоначально вводимых данных можно сократить следующим 
образом. Сначала введите данные о водителях в файл МЕШ1, 
затем, скопируйте номерные знаки из файла МЕЮ1 в файл МВР2. 
После этого введите в файл МЕШ2 недостающую информацию. 

Копирование номерных знаков из поля И_2 файла МЕЮ1 в 
файл МЕШ2 можно осуществить посредством операции добавле¬ 
ния записей в файл МЕШ2 из файла МЕЮ1. При этом будут 
добавляться только данные одноименных полей. Для этого после 
ввода всей информации в файл МЕШ1 в окне Раіа УЦ выберите 
файл МЕШ2 и перейдите на экран модифицирования его 
структуры (клавишами 5НІМ-Р2) . 
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Таблица 2.7. Файл МІШ1 


н 



В 

КАТ 

А11Т0 

Н_1 

1 

Архипов Сергей 
Иванович 

23/03/49 

10 

А,С 

Родился 23 
марта 1949 г. 
в Москве 

34-59 ММС 

2 

Бронзов Сергей 
Васильевич 

12/11/60 

5 

В,С 

Родился 12 
ноября 1960 г. 
в Харькове 

09-33 ММД 

3 

Безродный Владимир 
Михайлович 

05/09/53 

Н 

А.В 
С.Е 

Родился 5 
сентября 1953 г 
в Москве 

99-38 ММС 

4 

Бородулин Алексей 
Владимирович 

31/12/60 

И 

С 

Родился 31 
декабря 1960 г. 
в Киеве 

01-01 ММД 

5 

Ермишкин Юрий 
Иванович 

06/05/45 

11 

С.Е 

А 

Родился 6 июня 
1945 года 
в Москве 

78-99 ММС 

6 

Малонушенко Юрий 
Николаевич 

21/11/64 

6 

А,В 
С 

Родился 21 
ноября 1964 г. 
в Омске 

35-68 ММД 

7 

Поляков Геннадий 
Михайлович 

17/07/39 

19 

В,С 
Е 

Родился 17 июля 
1939 в Москве 

43-92 ММС 

8 

Коваль Александр 
Николаевич 

30/03/65 

3 

А,С 

Родился 30 июня 
1965 г. в Киеве 

59-31 ММД 

9 

Садчиков Андрей 
Викторович 

13/01/57 

8 

С 

Родился 5 
августа 1965 г. 
в Тамбове 

99-99 ММД 

10 

Строков Олег 
Валерьевич 

05/08/65 

N 

в,С 

Родился в 
Зеленограде 
в 1965 г. 

34-56 ММД 

11 

Старченко Сергей 
Николаевич 

22/04/43 

в 

с 

Родился в 

Москве 22 марта 
1943 г. 

01-34 ММД 


Таблица 2.8. Файл МІШ2 



$0$ 

МАЙ 

6_И 

34-59 ММС 

Не исправен 

ЗИЛ-131 

В автопарке 

09-33 ММД 

Исправен 

ГАЗ-53 

В автопарке 

99-38 ММС 

Исправен 

ГАЗ-53 

В рейсе 

01-01 ММД 

Исправен 

ЗИЛ-131 

В рейсе 

78-99 ММС 

Исправен 

ЗИЛ-131 

В рейсе 

35-68 ММД 

Не исправен 

ЗИЛ-131 

В капремонте 

43-92 ММС 

Исправен 

ЗИЛ-130 

В рейсе 

59-31 ММД 

Исправен 

ГАЗ-53 

В рейсе 

99-99 ММД 

Исправен 

ЗИЛ-131 

В рейсе 

34-56 ММД 

Исправен 

ГАЗ-53 

В автопарке 

01-34 ММД 

Исправен 

ГАЗ-53 

В рейсе 
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Таблица 2.9. Файл МІШЗ 


И_6 

0 Р 

0 V 

0_Р 

СО 

15 

ѴКМ 

ѴЕЗ 

Я6К 

И_2 


Станки ЧПУ 

Одинцово 

Г орький 

24/03/89 

25/03/89 

300 

14 

3.0 

44.00 

34-56 

ммд 

Стройматериалы 

Москва 

Ярославль 

22/05/89 

20/05/89 

300 

13 

4.0 

50.00 

78-99 

ммс 

Мебель 

Москва 

Калуга 

30/06/89 

01/07/89 

300 

12 

1.0 

46.00 

34-56 

ммд 

Мебель 

Москва 

Г орький 

25/07/89 

26/07/89 

400 

16 

3.0 

69.00 

99-99 

ммд 

Стройматериалы 

Болшево 

Тула 

10/10/89 

12/10/89 

200 

8 

2.0 

33.00 

78-99 

ммс 

Техника 

Москва 

Подольск 

15/10/89 

15/10/89 

40 

2 

3.0 

8.00 

99-99 

ммд 

Двигатели 

Москва 

Рязань 

12/10/89 

14/10/89 

600 

22 

3.0 

72.00 

34-56 

ммд 


Таблица 2.10. Файл МЕШ4 


МАЯ 

5КК 

6К2 

Й5Х 

ГАЗ-53 

70 

3 

14 

зил-ізо 

80 

5 

15 

ЗИЛ-131 

75 

6 

17 


Затем в меню АррепсІ установите курсор на позицию 
АррепсІ гесогсЬ (гот СІВА5Е (ііе (добавить записи из сІВА$Е-фай- 
ла) и из высветившегося вертикального меню выберите файл 
МЕШ1. В результате выполнения операции все данные, содержа¬ 
щиеся в поле N„2 файла МЕШ1, будут введены в поле N..2 
файла МВР2. 

Следует отметить, что ввод текста с клавиатуры можно 
выполнять в двух режимах. В режиме ІП5 (нажата клавиша Іп$, 
что отмечается словом Іп$ в правой части нижней информацион¬ 
ной строки экрана) символы вводятся с раздвижкой всего текста 
вправо. В альтернативном режиме (переключается повторным 
нажатием клавиши Іп$) символы вводятся по имеющемуся на 
экране тексту. Режим Іп$ целесообразно применять при вставке 
слов и предложений в ранее введенный текст, а альтернативный 
режим при замене этого текста. В ряде случаев объем ручной 
работы по вводу информации можно сократить посредством 
копирования данных из поля предыдущей записи в это же поле 
последующей. Для этого надо установить курсор в поле 
последующей записи и нажать клавиши 5ЫК-Р8. 

Объем работы при добавлении новых записей можно 
сократить, установив режим автоматического копирования данных 
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всех полей последней записи в новую добавляемую запись с 
помощью команды $ЕТ САККѴ ОИ в командном режиме или с 
помощью меню ТооІ$ сервисных функций. В последнем случае 
надо сначала выбрать позицию $еНіпд$ этого меню, затем в 
подменю Орііопз установить значение ОИ опции Саггу. 

Добавление новых записей по-одной можно выполнить с 
помощью позиции Ас1(1 пеж гесогвх меню Вгожхе или Есііі* или 
просто нажатием клавиши Вниз, находясь на последней записи. 
В последнем случае в нижней строке экрана высвечивается 
сообщение АсІсІ пеж гесогсЬ ? (У/И). Для ввода нужно нажать 
клавишу V, а при отказе - N (перед нажатием клавиш У или N 
следите за тем, чтобы клавиатура была переключена на режим 
ввода латинских букв). При установленном режиме $ЕТ САВВУ 
ОИ все поля последней записи копируются в добавленную 
запись. Следует отметить, что если никаких изменений в 
последней скопированной записи не делать, то для добавления 
в файл копии предыдущей записи нужно нажать клавишу Вниз 
дважды. 

Чтобы не выполнять рутинную работу по вводу данных в 
созданные Вами файлы БД, можно скопировать эти данные из 
эталонных учебных файлов с именами ВР1-В04. Эта операция 
выполняется так же, как и при копировании поля Ы_2 из файла 
МВР1 в файл МВР2 с той разницей, что теперь надо добавить 
записи из эталонных учебных файлов ВЭ1-В04 в созданные Вами 
файлы МВ01-МВР4. Поскольку имена полей одинаковые, то все 
данные из эталонных учебных файлов будут переписываться в 
Ваши файлы. 


2.5. ЗАПРОСЫ НА ПОИСК И ОТБОР ДАННЫХ 

После того как создана структура файла БД и введена 
информация, обычно требуется отбирать и выводить на экран 
или на печать те данные, которые отвечают поставленной задаче. 
Для этого формируются запросы на отбор необходимых данных. 
Запросы на отбор позволяют формировать так называемые 
выборки. Выборка представляет собой данные из одного или 
нескольких файлов БД, которые не существуют в виде самостоя¬ 
тельного файла, а только высвечиваются на экране как результат 
выполнения запроса. 

Кроме отбора данных можно формировать запросы с целью 
обновления данных. Выше был рассмотрен ручной способ ввода 
и обновления данных в экранных формах Вгомгсе и Есііі. 
Обновление с помощью запросов позволяет сократить время на 
этот процесс за счет автоматического отбора только тех записей, 
которые действительно требуется обновить, а также автоматиза¬ 
ции других операций, например, по замене одних данных 
другими, выполнения арифметических действий и т.д. 
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Разработанный запрос представляет собой программный 
файл, который записывается в каталог. Имя этого файла высвечи¬ 
вается в окне запросов на панели УЦ. Запрос на отбор данных 
можно использовать многократно, посредством выполнения 
созданного и записанного на диске программного файла запроса. 

Запросы можно создавать с помощью шаблона файла 
(запросы по образцу) и в специальном окне, которое размеща¬ 
ется справа в средней части экрана. Для каждого запроса на 
отбор данных нужно обязательно сформировать один шаблон 
вывода данных, в котором помещаются поля, выводимые на 
экран. В одном запросе часть критерия отбора данных можно 
помещать в шаблон файла, а остальную часть в окне. Запросы 
на обновление данных в отличие от запроса на отбор позволя¬ 
ют обрабатывать только один файл БД. 

Для создания запроса необходимо выбрать позицию 
<сгеа!е> в окне Оиегіез панели УЦ. Предварительно целесооб¬ 
разно открыть файл, в котором требуется отбирать данные. На 
экране появится меню этого окна с позициями 1.ауоиі (оформле¬ 
ние запроса), Ріеісіз (поля) и др. Если Вы не открыли файл, то 
это можно сделать, выбрав позицию АсЫ Іііе іо яиегу в меню 
І.ауоігі (вспомните, что значит выбрать позицию меню). На 
экране высветится список имен файлов в текущем директории. 
Выбор имени этого файла в окне приводит к его открытию и 
выводу его шаблона на экран. Таким же способом выводятся 
шаблоны и других файлов. Присутствие на экране шаблонов 
нескольких файлов требуется, наПример, при их связке. Шаблон 
файла можно удалить с экрана, выбрав позицию Кетоѵе (Не Ігот 
Яиегу этого же меню. 

Ввод поля файла в шаблон вывода выполняется клавишей Р5 
после предварительной установки курсора в требуемое поле в 
шаблоне файла. Удаление поля из шаблона вывода также 
выполняется клавишей Р5 после предварительной установки 
курсора в соответствующее поле шаблона вывода. Ввод и 
удаление поля из шаблона вывода можно также выполнить с 
помощью позиций АсісІ йеісі* іо ѵіеж и Кетоѵе і\е\4 (гот ѵіеж 
меню І.ауоігі, предварительно установив курсор в соответствую¬ 
щее поле в шаблонах файла или вывода. Сразу все поля файла 
можно поместить в шаблон вывода клавишей Р5, предварительно 
установив курсор в шаблоне файла под его именем. Повторное 
нажатие этой клавиши в положении курсора под именем файла 
вызывает удаление всех полей из шаблона вывода. 

Для перемещения одного поля в другое место в шаблоне 
вывода нужно установить на него курсор, нажать клавишу Р6 
(высветить), затем нажать клавишу Р7, переместить курсор на 
новое место и нажать Епіег. Перемещение нескольких полей 
выполняется аналогично после их подсветки, которая осуществля¬ 
ется передвижением по полям навигационными клавишами после 
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нажатия клавиши Р6. Подсветку также нужно зафиксировать 
клавишей Епіег. 

Если все шаблоны файлов не умещаются на одном экране 
(их может быть до 8), то переход к следующему экрану 
выполняется клавишей Рдйп, а к предыдущему - РдЦр. 

Движение по полям шаблонов выполняется, как и по полям 
файла БД клавишами ТаЬ (вправо) и $НіН-ТаЬ (влево), в 
крайнее левое и правое поля - клавишами Ноте и ЕпсІ, а 
переход из шаблона файла в шаблон вывода и обратно - 
клавишами РЗ и Р4. 

Формирование шаблона вывода целесообразно выполнять в 
два этапа: сначала вводить сразу все поля файла и затем удалять 
ненужные. Как уже упоминалось, ввод всех полей осуществляется 
клавишей Р5 после предварительной установки курсора в 
шаблоне файла под его именем. Повторное нажатие клавиши Р5 
в том же положении курсора вызывает удаление всех полей из 
шаблона вывода. Клавиша Р5 позволяет также вводить и удалять 
поля файла по одному в шаблон вывода после предварительной 
установки курсора в требуемое поле в шаблоне файла. 

Кроме обычных полей в шаблон вывода можно помещать 
вычисляемые поля. В эти поля заносятся данные, получаемые в 
результате выполнения различных (не только арифметических) 
операций. Вычисляемые поля создаются в специальном шаблоне. 
Для этого следует выбрать позицию Сгеаіе саісиіаіесі (іеісіз меню 
Ріеісіз. 

В пустую графу шаблона вычисляемых полей вводится с 
клавиатуры вычисляемое выражение, которое включает одно или 
несколько имен полей файла БД, и операторы выполнения 
действий с ними. В число этих операторов входят арифметичес¬ 
кие и логические операторы, а также функции СІВА5Е IV. Имена 
полей, операторы и функции можно также ввести в шаблон из 
таблицы, высвечиваемой клавишами 5ЫН-Р1. Передвижение по 
этой таблице осуществляется навигационными клавишами, а ввод 
значения - клавишей Епіег. Следует отметить, что с помощью 
этой таблицы чаще всего можно ввести не целое выражение, а 
только его элементы, которые обычно нужно редактировать для 
формирования синтаксически правильного вычисляемого выраже¬ 
ния. 

После сформирования выражения вычисляемого поля ему 
требуется присвоить имя, что выполняется выбором позиции Есііі 
ііеісі пате меню Ріеісіз (высвечивается окно, в которое вводится 
имя поля). Имена полей должны быть уникальными. Для 
перемещения созданного вычисляемого поля в шаблон вывода 
используются те же клавиши и меню, что и для обычных полей. 

Как уже упоминалось, условия (критерии) для отбора 
данных из файлов БД в запросе можно сформировать двумя 
способами: с помощью шаблона файлов (так называемый запрос 
по образцу) и в специальном окне - или их комбинацией. 
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Возможности по формированию условий для отбора этими 
способами различны. В шаблоне файла можно, кроме формиро¬ 
вания условия отбора, еще задать выполнение некоторых 
дополнительных действий (осуществлять связку нескольких 
файлов, выполнять операции по агрегированию данных и др.). 
Этим способом легче составлять запрос, так как не требуется 
вводить логические операторы. Однако только в специальном 
окне можно включать в поисковое выражение поля типа Мето, 
но нельзя задавать никаких действий помимо формирования 
условия и труднее формировать сложное условие, так как 
требуются некоторые знания математической логики (логические 
операторы и способы построения сложных запросов). 

Сложный запрос состоит из элементарных условий, которые 
объединяются логическими операторами. В общем случае 
элементарное условие включает имя поля, следующий за именем 
оператор и поисковое значение поля. 

При формировании запроса с помощью шаблона файлов 
элементарное условие вводится в графу соответствующего поля 
без имени поля. Размещение элементарных условий в одной 
строке шаблона соответствует логической связке .АИР. (И), а в 
разных строках шаблона - связке .ОК. (ИЛИ). Следующая строка 
шаблона файла раскрывается навигационной клавишей Вниз. 
Операторы элементарных условий приведены в табл. 2.11. 

Оператор " =" в элементарной условии, помещаемом в 
шаблон файла, можно не ставить, так как предполагается, что 
если введено значение без оператора, то такое условие означает 
отбор записей с данными, равными этому значению. После 
оператора І-іке (подобно) записывается значение - строка в 
кавычках, которую требуется найти. Эта строка может включать 
знаки замещения * и ? при поиске символов. Знак * замещает 
любое количество символов, а знак ? - один символ. 


Таблица 2.11. Операторы элементарных условий 


Оператор 

Описание 

> 

Больше чем 

< 

Меньше чем 

= 

Равно 

<> МАИ # 

Не равно 

>= 

Больше или равно 

< = 

Меньше или равно 

$ 

Содержит 

Ике 

Подобно 

Зоипгіз Ііке 

Звукоподобно 


60 






С оператором ЗоипсІ; Ііке также вводится символьная строка 
в кавычках. Этот оператор выполняет сравнение заданной и 
искомой строк в соответствии с кодами, определяющими 
звучание этих строк. Если коды звучания двух разных строк 
одинаковые, то эти строки звукоподобны и условие поиска 
выполняется. 

При формировании элементарного условия вместо явного 
значения можно задавать его неявно в виде имени поля. Такой 
тип условия требуется, например, при отборе записи со 
значениями некоторого числового поля, превышающими все 
значения другого числового поля. 

Примером служит запись элементарного условия в поле 
роіеі шаблона файла > = роіеі -і $ для отбора записей со 
значениями в поле роіеі, больших или равных любым значениям 
в поле роіеі минус пять. Вместо имени поля можно ввести имя 
любой переменной, например, гг, и это же имя поместить в 
графу соответствующего поля шаблона файла. Если в элементар¬ 
ное условие входит поле из другого файла, то перед его 
именем необходимо поставить имя файла со стрелкой вправо по 
форме: <имя файла>-><имя поля>. 

При формировании запроса в специальном окне применяются 
обычные правила составления логического условия. Сложное 
условие представляет собой комбинацию элементарных условий, 
соединенных логическими связками .АИй., .ОН. и .ИОТ. Элемен¬ 
тарное условие в отличие от условия, вводимого в шаблон 
файла, записывается по полной форме, т.е. из трех компонентов: 
имени поля, оператора и значения. При формировании сложного 
условия могут использоваться круглые скобки для разграничения 
действия логических операторов. 

Обычно при выполнении запроса осуществляется отбор 
(фильтрация) записей файла БД в соответствии с заданным 
условием. Можно запрос на фильтрацию превратить в запрос на 
поиск первой записи, удовлетворяющей заданному условию, если 
после критерия отбора (элементарного условия) поместить слово 
РІМО. 

Специальное окно для формирования условия отбора записей 
вызывается выбором позиции А66 сопсШіоп Ьох меню СопсШіоп. 
Позиция Реіеіе сопсШіоп Ьох этого же меню позволяет удалить 
окно. Установка клавишей Епіег значения ѴЕ$ позиции данного 
меню $Ьож сопсШіоп Ьох открывает окно, а значения ИО его 
закрывает. После закрытия окно удаляется с экрана, но не из 
памяти, а на экране остается маркер - слово СОНОІТІОЫ. 
Впоследствии окно можно активизировать, переместив курсор на 
маркер клавишами РЗ или Р4 или установив значение ѴЕ5 в 
позиции $Ьож сопсШіоп Ьох. 

Как уже упоминалось, при формированиии запроса с 
помощью шаблона файла можно, кроме элементарных условий, 
задавать еще и выполнение дополнительных действий: вывод 
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отобранных записей в упорядоченном виде, группирование 
записей, агрегирование сгруппированных числовых данных с 
помощью специальных функций, связку файлов, представленных 
в запросе своими шаблонами, по общему полю. 

Задание вывода отобранных данных в упорядоченном виде 
выполняется вводом в одну или несколько граф шаблона файла 
операторов сортировки: а$сЫ (в возрастающем порядке), сізсИ 
(в убывающем порядке), азссНсШ (в возрастающем порядке 
без различия прописных и строчных букв), скссНсіИ (в убываю¬ 
щем порядке без различия прописных и строчных букв). Эти 
операторы можно набрать с клавиатуры или выбрать из таблицы, 
высвечиваемой после выбора позиции $оіі оп 1Ьі$ (іеЫ меню 
Ріеісіз. Если в графе шаблона файла уже есть элементарное 
условие для отбора данных, то оператор упорядочивания и 
условие должны разделяться запятой. 

Группирование данных файла БД представляет собой подбор 
записей с одинаковыми значениями полей в один блок. По 
умолчанию сгруппированные блоки данных располагаются по 
возрастанию чисел для числовых полей или А5СІ 1-кодов для 
символьных полей. Этот порядок можно изменить на обратный, 
введя альтернативный оператор упорядочивания. Для выполнения 
группирования выбирается позиция Сгоир Ьу после предваритель¬ 
ной установки курсора в соответствующую графу шаблона файла. 
Отметим, что вместо выбора позиции Сгоир Ьу можно ввести 
эти слова в графу шаблона непосредственно с клавиатуры. 

Операторы агрегирования включают: $ІІМ - суммирование 
значений полей; АѴС, МІЫ, МАХ - определение среднего, 
минимального и максимального значений полей; сит - подсчет 
количества отобранных записей. Часто операторы агрегирования 
используются в сочетании с оператором группирования. При этом 
группирование применяется по текстовым полям, а агрегирование 
по числовым полям этих же записей, что позволяет, например, 
вычислять различные функции агрегирования в группах (подыто- 
ги, минимальное, максимальное и среднее значения). 

В нашем примере информационной задачи учета автоперево¬ 
зок технические характеристики автомобилей и данные об их 
парке хранятся в отдельных файлах. При получении сведений о 
грузообороте можно использовать связь этих файлов по полю 
МАК (марка автомобиля) и из файла технических характеристик 
извлекать численные значения грузоподъемности автомобиля для 
расчета итоговых показателей за определенный период времени. 

Связывание файлов по общему полю осуществляется вводом 
имени одной и той же переменной в связываемые поля файлов. 
Это можно выполнить с клавиатуры или выбором позиции Сгеаіе 
Ііпк Ьу роіпііпд меню Ьауоиі В последнем случае в качестве 
такой переменной автоматически вводится имя ЬіпкИ, где N - 
порядковый номер связи между полями файлов БД. После 
установления связи между файлами из них выводятся только те 
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записи, которые имеют одинаковое значение связанных полей. 
Если требуется вывести все записи связанных файлов, то перед 
одной из связывающих переменных надо поставить слово Еѵегу. 
В том случае, когда необходимо вывести только одну (первую) 
запись из группы записей с одинаковыми значениями связанных 
полей, следует поставить слово Рігзі. 

Связывание файлов можно использовать как формальный 
прием при формированиии специальных типов запросов на отбор 
данных из одного файла, в котором требуется сравнить каждую 
запись со всеми другими в файле. В этом случае шаблон файла 
нужно дважды вызвать на экран. Дубликат помечается буквой 
В в верхнем левом углу шаблона файла. После связки этих двух 
шаблонов файлов по какому-либо полю формируется запрос, при 
выполнении которого производится сравнение каждой записи 
файла со всеми другими. В шаблон вывода такого запроса 
можно вводить одно и то же поле несколько раз. При этом 
высвечивается подсказка изменить имя поля. После изменения 
поле вводится в шаблон вывода, где указывается новое и старое 
имя. 

Кроме полей в состав шаблона файла можно включить 
созданные ранее пользователем сложные индексы (простые 
индексы полей входят в состав списка указателей индексов в 
связанном множественном индексном файле и подключаются 
автоматически при выполнении соответствующих операций). Эти 
индексы представляют собой псевдополя, которые можно 
использовать для связи с другими файлами БД и сортировки. 
Для включения сложного индекса выбирается позиция Іпсіисіе 
іпсіехез меню Ріеісіз. Созданные ранее сложные индексы 
высвечиваются в конце шаблона файла. В них стоит знак # и 
выражение индекса. Одновременно при выборе этой позиции 
знак # помещается в каждое индексированное поле (с простым 
индексом) для напоминания пользователю об индексации 
используемого файла БД. 

Запись запроса в каталог на диске осуществляется выбором 
позиции $аѵе іЬіз яиегу меню І.ауоиі или позиции 5аѵе сЬапдез 
апсі ехіі меню Ехіі. Те же действия выполняются и при нажатии 
клавиш СігІ-ЕпсІ. Перед записью высвечивается окно, в которое 
нужно ввести с клавиатуры имя запроса и нажать Епіег. При 
выборе позиции АЬапсІоп сЬапдез апсі ехіі меню Ехіі осуществля¬ 
ется выход из экрана создания/модификации запроса без 
сохранения. 

Для проверки правильности формирования условий отбора 
данных, введенных в запрос, можно, не выходя из экрана 
создания/модификации запросов, просмотреть отобранные записи, 
нажав клавишу Р2. Возврат на экран создания/модиф акации 
запроса выполняется нажатием клавиш 5НІІІ-Р2 или выбором 
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позиции Тгапзіег іо Оиегу Резідп меню Ехіі экранной формы 
Вгоѵѵзе или Есііі. 

Активизация запроса осуществляется выбором его имени в 
окне Оиегіез панели УЦ. После этого высвечивается горизонталь¬ 
ное меню с тремя позициями ѵіе\ѵ, МосІНу циегу, Оі$рІау 

сіаіа. Выберите позицию ІІ$е ѵіе\ѵ. Для просмотра отобранных 
данных переместите курсор на позицию йізріау (Іаіа и нажмите 
клавишу Епіег. 

Отобранные в результате выполнения запроса записи из 
нескольких файлов можно сохранить в виде одного файла БД с 
помощью позиции Ѵ^гііе ѵіе\ѵ а$ сІаіаЬазе Іііе позиции І.ауоиі. 
Перед сохранением требуется ввести с клавиатуры имя файла. 
Для удобства пользователя можно ввести словесное описание 
созданного запроса, которое высвечивается при его запуске из 
окна Оиегіез панели УЦ. Окно для ввода этого описания 
высвечивается выбором позиции Есііі сІе$сгірііоп оі циегу меню 
І.ауоиі. Сохранение описания запроса после его ввода с клавиату¬ 
ры выполняется клавишей Епіег. 

Как уже указывалось, можно формировать запросы не 
только на отбор записей, но и на обновление данных. В этих 
запросах нельзя изменять данные, полученные операторами 
агрегирования, и вычисляемые поля. Можно обновлять данные, 
полученные при сортировке по одному полю, если это поле 
проиндексировано. 

При формировании запросов на обновление используются 
только шаблоны файлов. В число операций по обновлению 
данных входят: замена данных в полях записей, добавление 
записей из другого файла, пометка записей для их последующе¬ 
го удаления и уничтожение пометок на удаление. Для этого 
используются следующие операторы обновления: КЕРІ-АСЕ 
(замещение данных), АРРЕЫй (добавление записей), МАРК 
(пометка записей для удаления), ІЖМАКК (уничтожение 
пометок для удаления записей). Операторы обновления следует 
вводить с клавиатуры в шаблон файла под именем файла БД 
или посредством выбора из списка, высвечиваемого выбором 
позиции Зресііу ирсіаіе орегаііоп меню Црсіаіе. 

Над именем файла в шаблоне после ввода оператора 
обновления появляется слово Тагдеі, означающее, что данный 
файл установлен в режим обновления в отличие от других 
файлов, которые могут оставаться на экране. При этом шаблон 
вывода, если он до этого был, исчезает с экрана. Для выполне¬ 
ния операции замещения данных необходимо в замещаемое поле 
ввести ключевое слово жііН, за которым следует выражение, 
определяющее вводимое значение. Кроме того, можно указывать 
фильтрующие условия, как и в запросе на отбор. В состав 
выражения могут входить числовые значения, имена полей 
данного файла и их комбинации с операторами и функциями, 
применимыми для соответствующих полей. 
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Например, можно заменить значение числового поля тем же 
значением, умноженным (разделенным, вычтенным и т.д.) на 
заданное число, или заменить значениями других полей, 
связанных арифметическими операторами. Содержимое символь¬ 
ных полей можно, например, замещать сцепленными или 
обработанными соответствующими функциями данными из других 
полей этого файла и т.д. 

Операция добавления записей в файл с помощью запроса на 
обновление имеет смысл только в случае добавления записей из 
другого (передающего) файла, поскольку добавление данных в 
файл с клавиатуры можно осуществить после выполнения запроса 
на отбор данных (но только одного файла БД) или с помощью 
меню Раіа УЦ. Для этого шаблон передающего файла также 
должен быть на экране. В графы шаблона принимающего файла, 
в которые вводятся данные, надо ввести имена полей из 
передающего файла. Допускается также вместо имени поля 
вводить любое имя, однако в этом случае необходимо поместить 
это же имя в соответствующую графу поля передающего 
файла. 

Если в одно поле принимающего файла требуется поместить 
данные из нескольких полей передающего файла, то в графе 
этого поля в шаблоне принимающего файла записывается 
выражение сцепления полей в виде имен полей, разделенных 
знаком " +". Вообще в графах шаблона принимающего файла 
можно записывать любые выражения (включающие операторы 
и функции), допустимые для действий с этими типами полей. В 
графах шаблона передающего файла можно записывать условия 
отбора передаваемых записей. 

При выполнении операции пометки записей, предназначенных 
для удаления, можно вводить условия отбора этих записей. Если 
эти условия не введены, то помечаются все записи файла. 
Удаление помеченных записей из файла БД можно выполнить, 
выбрав позицию Егазе тагкесі гесогск подменю Огдапіхе из меню 
создания структуры файла БД. Более короткий способ вызова 
этого подменю - клавишами 5ЫН-Р2 из окна Оаіа после установки 
курсора на имя файла БД. 

Уничтожение пометок на удаление записей выполняется в 
соответствии с заданными в запросе условиями отбора записей. 
Если условия не заданы, то уничтожаются все пометки на 
удаление. 

Выполнение запроса на обновление осуществляется выбором 
позиции Регіогт іЬе ирсіаіе меню ІІрсІаіе. Предварительно 
выводится предупреждающее сообщение и после подтверждения 
запрос выполняется. Можно записать обновленный файл БД на 
диск, выбрав позицию У^гііе ѵіеѵѵ а$ сІаіаЬазе Іііе меню І.ауои1. 

Сохранение запроса на обновление в каталоге, выход без 
сохранения, выполнение запроса без сохранения и ввод словесно¬ 
го описания выполняются так же, как и для запроса на отбор 
— 6340 
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данных. После сохранения в каталоге УЦ запрос на обновление 
для отличия от запросов на отбор помечается знаком * слева 
от имени. 

Ранее созданный запрос можно выполнить с панели УЦ, 
выбрав его имя в окне запросов. После этого высвечивается 
меню с позициями Мосіііу циегіез (для перехода к модификации' 
запроса) и Ріхріау сіаіа (на выполнение запроса с выводом 
данных на экран). 

Более короткий способ перехода к выполнению (модифика¬ 
ции запроса) - клавишами Р2 (5НІЙ-Р2) после предварительной 
установки курсора на имя файла запроса в окне на панели УЦ. 

Для усвоения материала создайте запросы на отбор данных 
на водителей из файла МВР1 по следующим признакам: 
стаж работы больше 7 лет (поле $_ Р); 
категория водительских прав В и С (поле КАТ); 
категория водительских прав Е или А; 
стаж работы больше 5 лет и категория Е. 

На учебной дискете эти запросы записаны под именами 
001-004. Если Вы используете для записи своих решений эту 
дискету или директорий РКІМЕК на жестком диске, в который 
записаны примеры учебной дискеты, то надо давать другие 
имена, чтобы учебные файлы не были заменены новыми 
файлами. В дальнейшем условимся, что файлам запросов, как и 
файлам БД, будут даваться имена, под которыми они записаны 
на учебной дискете, но с добавлением впереди буквы М, 
например файлам 001-004 будут присвоены имена МО01-МО04. 

Для формирования первого запроса в поле $_К шаблона 
файла введите условие >7. Теперь остается только присвоить 
имя запросу МООІ и сохранить в памяти, выбрав позицию $аѵе 
сЬапдез апсі ехіі меню Ехіі. Ввод имени выполняется с клавиату¬ 
ры в окно $аѵе а$: по следующей форме 0:\0ВА$ЕІѴ\РКІМЕК\ 
МООІ. В этом окне имя диска и текущий маршрут по директори¬ 
ям высвечиваются по умолчанию, поэтому остается ввести только 
имя запроса. 


І.ауоиІ Ріеігіз СопсіИІоп 

Іірсіаіе Ехіі 

12:56:37 рт 

|мЬс!1.гіЬГ | 0_Я 


КАТ | 

> 

\ 

>7 



При формировании элементарных условий с использованием 
категории водительских прав нужно применять оператор 
отношения $ (содержит), поскопьку буквы нескольких категорий, 
которые имеет водитель, записываются в одно поле. Во втором 
запросе используйте этот оператор: в графу КАТ шаблона файла 
поместите логические условия $"В",$"С" (буквы латинские). 
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І_ауои* Ріеісіз Сопсіиіоп ІІрсіаѣе Ех 1 *Ь 12:57:31 рш 


ІМЫіІ.сіЬТ 

КАТ 

АУТО 

N.2 





Третий запрос отличается от второго типом логической 
связки .ОК. (ИЛИ), которая реализуется размещением элемен¬ 
тарных условий $"Е" и $"А" в разные строки шаблона. Надо 
ввести одно из них (безразлично какое) в первую строку 
шаблона под именем КАТ, затем нажать клавишу Вниз. Откроет¬ 
ся вторая строка, в которую надо поместить второе элементар¬ 
ное условие. 


Ьауои* Ріеісіз Сопсіиіоп УрсіаЪе ЕхИ 12:58:29 рш 


МЬ<І1.<ІЬТ 0_К 

$_К 

КАТ | 




> гп 


В четвертом запросе введите условие >5 в графу 5_К, а 
условие $"Е" в графу КАТ (связка условий по "И"). 


ІауоиЪ 

Г і е 1 сіз СопсіШоп 

Іірсіаіе Ех і і 

12:59:54 рш 

[мЬйІ.гіЬТ 

I 

5_К 

КАТ | 


1 

>5 

$”Е” | 


гѴіеѵ*- 

-- 

г--1 



М004 

МЬсі1-> 

НОМ 

МЬсІ 1 - > 

РАМ 

МЬсі1-> 

НАМ 

МЬсі1-> 

ОТС 

- > 


В качестве дополнительных примеров на поиск данных 
создайте запросы с включением поля даты и поля типа Мето. 
Например, отберем водителей по признакам: 
старше 45 лет; 
старше 25 и моложе 45 лет; 

имеющих категорию водительских прав В и моложе 35 лет: 
имеющих категорию водительских прав Е или моложе 30 

лет; 

родившихся в Москве; 

родившихся в Москве, имеющих категорию водительских 
прав А и старше 40 лет. 

Запросы с датой можно сформировать двумя способами: с 
указанием даты рождения или составив выражение, в которое 
входит возраст и функция, возвращающая текущую дату С 
помощью первого способа сформируйте элементарное условие 
вида: < = {01/01/45} и поместите его в графу Ь__В шаблона 
файла МІШ1. Присвойте этому запросу имя МО05. Следует иметь 
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в виду, что данные типа даты при формировании поискового 
выражения должны заключаться в фигурные скобки, что обозна¬ 
чает именно этот тип данных в отличие от символьных и 
числовых. 

Во втором способе сформируйте выражение < = ОАТЕ() 
45*365, которое также поместите в графу 0_К. Это выражение 
означает вычисление даты, являющейся разностью между 
текущей датой и возрастом, выраженным в днях. В этом случае 
автоматически будет определяться дата рождения, соответствую¬ 
щая заданному возрасту. Запишите этот запрос под именем 
МО06. 

Запросы на диапазон возраста являются сложными и 
формируются из двух элементарных условий, объединяемых 
логической связкой .АЫР. ("И"). Напомним, что в шаблоне 
файла эта логическая связка указывается неявно, в данном 
случае (для второго из дополнительных запросов) размещением 
обоих условий в одной графе через запятую: > = {01/01/45}, 
<= {01/01/65}. Запишите этот запрос под именем МО07. 

Как и в предыдущем запросе можно использовать функцию 
текущей даты. Тогда поисковое выражение в этом запросе, 
которому дадим имя МО08, будет выглядеть так: 

>= РАТЕП - 45*365,<= РАТЕП - 25*365 

При решении третьего примера (запишем его под именем 
МО09) сформируйте сложное условие типа "И", состоящее из 
двух элементарных, относящихся к разным полям, которые 
размещаются в одной строке в соответствующих полях: в поле 
КАТ $ "В", а в поле > = {01/01/55}. 

Четвертый пример отличается от третьего по своей структуре 
тем, что в нем нужно сформировать условие типа ИЛИ. В этом 
запросе, которому дайте имя МОЮ элементарные условия (для 
поля КАТ $ "Е", а для поля К > {01/01/60}) размещаются в 
разных строках шаблона. 

В следующем примере требуется осуществить поиск по полю 
типа Мето. Поиск по этому полю можно сформировать только 
в специальном окне. Для этого нужно сначала активизировать 
меню клавишей Р10, затем выбрать позицию АсІсІ сопсііііоп Ьох 
меню Сопсііііоп. В высветившееся окно с клавиатуры введите 
элементарное логическое условие полной структуры: "Москве" 
$ АІІТО. Заметим, что для поля типа Мето в элементарном 
условии значение ставится на первом месте. Для демонстрации 
этого примера в поле АІІТО должны быть введены данные о 
месте рождения. Запишите этот запрос под именем МОН. 

В шестом примере требуется сформировать сложное 
условие, состоящее из трех элементарных, объединенных 
логическими связками .АИО.: 

"Москве" $ АІІТО .АИР. "А" $ КАТ .АИЭ. 0_И < = {01/01/50} 
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Запишите это условие в окне и сохраните под именем 
МСН2. Этот же запрос можно сформировать как комбинацию 
части условия с полем типа Мето в окне, а остальной части в 
шаблоне файла. Сохраните этот запрос под именем МСНЗ. 

Как уже упоминалось, с помощью шаблона файла можно 
связать несколько файлов и создать запрос на отбор данных из 
связанных файлов. Проиллюстрируем это на примере двух 
файлов МЕШ1 и МВ02. Для этого свяжите их по общему полю 
2 и создайте запрос на отбор данных по тем автомобилям, 
которые не исправны (поиск по полю "Состояние" - $05 со 
значением "Не исправен"). 

Сначала выведите на экран (в любой последовательности) 
шаблоны файлов МІШ1 и МЕЮ2. Напомним, что вывод шаблона 
файла осуществляется позицией АсІсІ Іііе іо диегу в меню І.ауоиі. 
Не забудьте также ввести в шаблон вывода связываемые поля. 
Если в этот шаблон не войдут какие-либо из полей связанных 
файлов, то они не будут выводиться не только на экран, но и 
вообще не будут присутствовать в выборке. Таким образом, 
фактически в этом случае связка не будет реализована. Форми¬ 
рование полей шаблона вывода выполняется последовательно для 
каждого файла. При этом целесообразно сначала ввести все поля 
файла, а затем удалить ненужные. Поля каждого следующего 
файла будут добавляться в шаблон вывода. 

Можно также, наоборот, вводить в шаблон вывода только те 
поля, которые будут нужны. Напомним, что для ввода поля в 
шаблон вывода нужно клавишами РЗ/Р4 переместить курсор на 
шаблон файла, затем клавишами ТаЬ или 5ЬіН-ТаЬ передвинуть 
курсор на нужное поле и нажать клавишу Р5. Для перенесения 
поля, на котором установлен курсор, можно вместо клавиши Р5 
использовать позицию АсІсІ ІіеІсІ іо ѵіеж меню Ріеісіз. Для нашего 
примера в шаблоне вывода обязательно должны присутствовать 
поля, по которым осуществляется связка и поиск Ы_2, $05, 
мак и е_и, а также другие необходимые для вывода поля. 

Для связки файлов МЕШ1 и МЕШ2 по общему полю 2 с 
помощью клавиш $Ьі(і-ТаЬ надо переместить курсор на поле 
N.2, выбрать позицию Сгеаіе Ііпк Ьу роіпііпд меню Ьауоиі (в 
графе поля высветится слово ЫИКІ), клавишей РЗ перейти на 
шаблон файла МКЮ1, установив курсор в графу поля Ы__2 и 
нажав клавишу Епіег (в графе также высветится ІЛ4К1). Связка 
файлов выполнена. 

При формировании условия на отбор записей нужно перейти 
клавишей Р4 на шаблон файла МЕШ2 и в поле $05 ввести 
условие отбора записей: "Не исправен" (кавычки вводить надо, 
так как это поле символьного типа). 

После сформирования запроса можно ввести его описание, 
например: "Связка файлов МІЮ1, МЕШ2 по общему полю Ы_2 
и отбор данных о неисправных автомобилях". Для этого сначала 
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нужно выбрать позицию Есііі сіезсгірііоп оі яиегу меню І.ауоиІ . 
Теперь остается только присвоить имя запросу, например М014, 
и сохранить в памяти, выбрав позицию $аѵе сНапдез апсі ехіі 
меню Ехіі. Ввод имени выполняется с клавиатуры в высвеченное 
окно $аѵе а$ по форме: имя диска:\маршрут по директории 
ям\имя запроса, например 0:\0ВА$ЕІ Ѵ\РКІМЕК\МС114. 

Попробуйте теперь самостоятельно создать запрос на связку 
файлов БД: МВЭ1, МВ02 и МВРЗ по общему полю Н.2; МВ02 
и МВР4 по полю МАР - и отобрать данные о перевозках, 
выполненных водителями на расстояние свыше 300 км. Сохраните 
этот запрос под именем М015. 

При создании связки нужно иметь в виду, что с помощью 
меню связка файлов осуществляется парами и в общем поле 
каждой следующей пары автоматически записывается слово 
НИКп, где п - порядковый номер связываемой пары. Таким 
образом, в данном запросе в поле Ы_2 файла МВЭ1 будет 
стоять слово І.ІЫК1, в этом же поле файла МВР2 два слова 
І.ІЫК1 и ЫЫК2, разделенные запятой, а в файле МВРЗ - слово 
ЫЫК2. В общем поле МАР файлов МЕШ2 и МЕЮ4 будет стоять 
слово никз. 

Помимо меню связку файлов можно выполнить вручную с 
клавиатуры. Для этого нужно в общее поле связываемых файлов 
ввести какое-либо одно имя, например, в поле - имя И, 

а в поле МАК - имя 1.2. Ниже, в разделе разработки отчетов 
будет описано создание запросов двумя этими способами. 

Следует отметить, что существенным недостатком запросов 
на отбор данных из связанных файлов, создаваемых с помощью 
УЦ, является то, что они не дают возможности пользователю 
редактировать отобранную информацию. 

Опытные пользователи, знающие язык СІВА5Е IV, могут 
расширить возможный диапазон действий, выполняемых запроса¬ 
ми посредством модификации созданных и сохраненных програм¬ 
мных файлов запросов (имеют расширение .яЬе) с помощью 
текстового редактора. 


2.6. ЭКРАННЫЕ ФОРМЫ ВВОДА И ВЫВОДА ДАННЫХ 

В предыдущих разделах ввод информации в файлы БД и 
вывод ее на экран выполнялся в виде стандартных экранных 
форм Вгожзе и ЕсШ. В сІВАЗЕ IV имеется возможность разраба¬ 
тывать собственные формы ввода и вывода данных на экран. В 
этих формах поля файлов БД можно размещать в любом месте 
экрана, сопровождая их пояснительными надписями, обводить в 
рамки и вводить другие оформительские элементы. Важной 
особенностью пакета сІВАЗЕ IV является возможность вывода в 
окна на экране и редактирование полей типа Мето. 
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Кроме того, при установке курсора в поле файла БД можно 
высвечивать сообщения внизу экрана об особенностях и правилах 
ввода информации, контролировать ввод информации и т.д. 
Каждая экранная форма предназначается для ввода или вывода 
данных из определенного файла БД, имя которого записано в 
этой экранной форме. Этот файл можно изменить, модифицируя 
экранную форму. 

Разработанные формы представляют собой программные 
файлы, которые можно записать на диск и затем использовать 
многократно для просмотра и обновления информации на экране 
в удобном для пользователя виде. 

Перед созданием экранной формы целесообразно активизи¬ 
ровать (открыть) файл БД или выборку, которые будут 
выводиться на экран в разрабатываемой форме. Однако это не 
обязательно. Можно открыть требуемый файл и из меню 
разработки экранной формы. Разработка экранной формы 
начинается с выбора позиции <сгеаіе> окна Рогтз панели УЦ. 
После этого высвечивается горизонтальное меню, включающее 
позиции (.ауоігі, Ріеісіз, Ѵ/ог4*, СоТо и Ехіі и экран, покрытый 
мелкой сеткой. Выбор этих позиций приводит к открытию 
различных меню, позволяющих выполнять определенный круг 
действий по созданию экранной формы. 

Мелкая сетка играет определенную роль при размещении 
различных элементов в экранной форме. Наличие сетки означает, 
что экран ничем не заполнен. Удаление сетки означает заполне¬ 
ние экрана пробелами. Так, перемещение текста клавишей 
Пробел в режиме Іп$ возможно только по экрану, свободному 
от мелкой сетки. 

Удаление мелкой сетки осуществляется клавишей Пробел, а 
восстановление - клавишей 0е\ или Васкзрасе. Если два поля 
разделены мелкой сеткой, то они при выводе отделяются 
интервалом, равным числу позиций мелкой сетки между ними. 
Если мелкой сетки между пробелами нет, то поля при выводе 
прижимаются друг к другу. Кроме того, мелкая сетка служит 
основой для закрашивания областей экрана. Места экрана, в 
которых сетка отсутствует, нельзя раскрасить в любой цвет. При 
высвечивании экранной формы они будут иметь цвет периферий¬ 
ной части экрана. 

Меню І.ауоиі предназначено для общего оформления 
экранной формы, реализации короткого способа ввода всех 
полей на экран и назначения файла БД, если он не был открыт 
ранее. 

Существует два способа ввода полей на экран из файла БД - 
по одному полю или сразу всех полей. Все поля файла БД в 
том порядке, как они расположены в БД, можно ввести, выбрав 
позицию Оиіск Іауоиі меню І.ауоиі. В этом случае надо обяза¬ 
тельно предварительно открыть файл БД. При этом поля 
располагаются в столбик, каждое поле - на одной строке экрана. 


71 



Затем эти поля можно, поочередно передвигая, более удобно 
разместить на экране. Если в текущий момент нет активного 
файла или с данной формой нужно использовать другой файл, 
то его можно открыть, выбрав из окна, высвечиваемого после 
выбора позиции 1)$е сііНегепі сІаіаЬазе Іііе ог ѵіеѵѵ меню Ьауои! 

Передвижение и копирование одного или нескольких полей 
осуществляется соответственно клавишами Р7 и Р8, изменение 
размеров - клавишами 5ЫЙ-Р7. Перед перемещением и копиро¬ 
ванием одного поля или нескольких полей их надо высветить 
клавишей Р6. Добавление полей по одному осуществляется с 
помощью позиции АсІсІ ІіеІсІ меню РіеІс!$. Перед добавлением 
поля нужно установить курсор на то место, в котором будет 
располагаться поле. После выбора этой позиции высвечивается 
список полей файла БД, а после выбора имени поля появляется 
шаблон для изменения заданных по умолчанию параметров поля. 
Сохранение параметров поля выполняется клавишами Сігі-ЕпсІ. 

Более короткий способ для выполнения операций по 
добавлению поля - нажать клавишу Р5, также предварительно 
установив курсор на место, в котором должно располагаться 
поле. 

Удаление ненужного поля с экрана выполняется с помощью 
позиции Кетоѵе ІіеІсІ. После выбора этой позиции высвечивается 
список полей файла БД. Выбор имени приводит к удалению 
поля. Удалить поле можно также клавишей РеІ, предварительно 
установив курсор на поле. 

Поля типа Мето в экранной форме можно представить в 
скрытом виде, который обозначается на экране словом (марке¬ 
ром) тето (МЕМО) или в явном виде в окне заданных 
размеров в любом месте экрана. Маркер тето, записанный 
строчными (приписными) буквами, означает, что это поле пусто 
(заполнено). Скрытое поле переводится в оконную форму 
представления клавишами СЫ-Ноте после установки курсора на 
маркер. Нажатие клавиши Р9 переводит окно в полноэкранную 
форму представления. Для выхода из поля типа Мето следует 
нажать клавиши Сігі-ЕпсІ. 

Существуют два способа создания оконной формы поля типа 
Мето, которые соответствуют двум способам ввода полей на 
экран. Если используется способ ввода всех полей на экран с 
помощью позиции Оиіск Іауоиі меню ЬауоиТ, то нужно установить 
курсор на поле типа Мето и выбрать позицию Мосіііу ІіеІсІ 
меню РіеІсЬ. После этого высветится окно с позициями для 
установки параметров, в котором нужно в позиции Рі$рІау а$ 
клавишей Пробел выбрать значение \УІЫОО>Ѵ и нажать Сігі-ЕпсІ. 
Далее высветится окно поля Мето стандартных размеров, 
которое можно привести к нужным размерам или переместить. 
Для этого сначала надо установить курсор на рамку окна, затем 
нажать клавиши 5ЫН-Р7 или Р7. Затем можно приводить окно к 
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нужным размерам или перемещать его навигационными клавиша¬ 
ми Вверх, Вниз, Вправо и Влево. 

Если используется способ ввода полей в экранную форму по 
одному, то надо выбрать позицию АсІсІ ІіеІсІ меню Ріеісіз, затем 
в высветившемся окйе выбрать поле Мето и в появившемся 
после выбора поля шаблоне установить в позиции йізріау а$ 
клавишей Пробел значение ѵ/жоо>ѵ и нажать СігІ-Епсі. После 
этого надо переместить курсор в левый верхний угол предпола¬ 
гаемого окна Мето поля и нажать Епіег, затем переместить 
курсор в правый нижний угол окна и зафиксировать клавишей 
Епіег. В результате высветится рамка окна. 

Создание скрытой формы Мето поля при использовании 
способа ввода полей по одному выполняется сначала так же, как 
и оконной формы, но вместо значения в позиции 

йізріау а$ выбирается МАККЕК. После высвечивания рамки окна 
нужно переместить курсор в позицию, в которой должен быть 
маркер, и нажать Епіег. Окно исчезнет и появится маркер поля 
Мето. При использовании способа ввода сразу всех полей перед 
созданием скрытой формы поля Мето нужно сначала сформиро¬ 
вать оконную форму, как это описано выше. Затем установить 
курсор на рамку этого поля, выбрать позицию Мосіііу ІіеІсІ меню 
РіеІсІ$ и затем клавишей Пробел установить значение МАККЕК в 
позиции Оі$рІау а$ шаблона параметров поля, не забыв сохранить 
установленное значение клавишами СігІ-ЕпсІ. После этого нужно 
переместить курсор в место, в котором должно быть поле Мето 
и нажать клавишу Епіег. Окно исчезнет и появится маркер Мето 
поля. 

Созданные на экране поля Мето можно, как и другие, 
передвигать, копировать, изменять в размерах (исключая 
скрытую форму) и удалять с помощью позиции Кетоѵе ІіеІсІ и 
Мосіііу ІіеІсІ меню Ріеісіз или с клавиатуры теми же клавишами, 
что и для обычных полей. С помощью позиции Вогсіег Ііпе меню 
Ріеісіз можно изменить вид рамки окна Мето поля, установив 
одинарную (Зіпдіе), двойную (РоиЫе) линию или линию рамки 
из заданных символов (ІІзіпд $ресі!іесі сЕіагасіег). 

Позиция Мосіііу ІіеІсІ меню РіеІсІ* позволяет изменить 
различные параметры поля, в том числе шаблон и функции поля 
(кроме Мето и логических) и т.д. Шаблоны и функции поля 
определяют форму ввода и вывода данных в это поле. Шаблон 
поля представляет собой набор знаков в количестве, равном 
выводимой на экране ширине поля. Каждый знак действует на 
ту позицию поля, в которой он находится. Примером действия 
знаков шаблона служит ввод только цифр (знак 9) или только 
букв (знак А) и т.д. 

Для числовых полей можно использовать следующие знаки 
шаблона: 

9 - ввод и вывод цифр и знаков чисел; 

# - ввод и вывод цифр, пробелов и знаков чисел, 
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^ - определение положения десятичной точки при вводе 

и выводе чисел; 

г - разделение при выводе трех порядков чисел; 

* - замена при выводе лидирующих нулей чисел знаком *; 

$ - замена при выводе лидирующих нулей чисел знаком $. 

Для символьных полей используются следующие знаки 

шаблона: 

9 - ввод и вывод цифр; 

# - ввод и вывод цифр, пробелов и знаков чисел; 

А - ввод и вывод букв; 

N - ввод и вывод цифр и букв; 

! - преобразование строчных букв в прописные. 

Для логических полей используются знаки шаблона: 

Ь - ввод и вывод логических значений Т,Р,Ѵ и Ы; 

X - ввод и вывод любого символа; 

V - ввод и вывод логических значений V и N. 

Другие знаки в составе шаблона будут вводиться как 
символы данных в соответствующую позицию поля, если не 
задана функция поля К. 

Изменение шаблона поля, заданного по умолчанию, осущест¬ 
вляется выбором позиции Тетріаіе подменю Мосіііу Ііеісі меню 
РіеІсІ5. Знаки шаблона вводятся в высвечиваемое поле с клавиату¬ 
ры. 

Функции поля являются дополнительным средством обра¬ 
ботки данных и позволяют кроме установленного шаблоном 
режима ввода и вывода информации выполнять аналогичные и 
дополнительные действия по обработке вводимых и выводимых 
данных. Функции поля в отличие от шаблона служат для 
различных преобразований целых полей. Совместное использова¬ 
ние функций и шаблонов поля дает возможность комбинировать 
устанавливаемые ими действия. 

Функция поля задается выбором соответствующей позиции 
в окне, высвечиваемом после выбора позиции Рісіиге іипсііопв. 
В начальном состоянии все функции выключены (состояние ОРР). 
Выбор функции приводит к ее включению (состояние ОРР 
меняется на ОИ). 

Для числовых полей используются следующие функции: 

I. - вывод лидирующих нулей чисел; 

2 - вывод пробелов вместо нулевого значения числа; 

$ - вывод числа со знаком валюты; 

^ - вывод числа в записи с порядком (научная запись 

числа). 

Для символьных полей применяются следующие функции: 

А - ввод только букв; 

! - преобразование строчных букв в прописные; 

К - ввод любых символов как данных в поле; 

5 - прокрутка навигационными клавишами информации в 

поле экранной формы; 
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М - выбор клавишей Пробел значений поля из созданного 
списка. 

На практике для символьных полей часто используются 
функции поля $ и М. Первая применяется для установки 
возможности прокрутки информации в поле на экране, размер 
которого меньше, чем исходный размер поля в файле БД, а, 
вторая - для создания списка альтернативных значений поля. 
После их выбора высвечивается окно: в первом случае для ввода 
ширины поля, внутри которого требуется прокручивать данные, 
а во втором - для ввода списка значений поля, которые 
впоследствии при использовании формы можно будет вызывать 
клавишей Пробел. Значения списка вводятся с клавиатуры и 
разделяются запятыми. 

Шаблон и функции поля не применяются для полей Мето 
и полей типа даты, а для логических полей можно использовать 
только шаблоны. 

Кроме шаблонов и функций для каждого поля можно задать 
ряд установок, которые позволяют сделать более удобной работу 
с данными в созданной экранной форме: установить защиту от 
обновления содержимого поля, задать условие, разрешающее 
обновлять данные в поле, дать указание о выводе внизу экрана 
сообщения при входе курсора в это поле, копировать в поле 
текущей записи значение из предыдущей записи, установить 
начальное значение данных в поле, обеспечить проверку на 
диапазон вводимых числовых данных, задать условие, когда в 
поле можно ввести новые данные, задать вывод внизу экрана 
сообщения, если условие для ввода в поле данных не выполня¬ 
ется. 

Эти установки задаются выбором позиций меню, высвечива¬ 
емого после выбора опции Есііі орііопз меню РіеІсІ$. После 
выбора позиции в зависимости от ее назначения требуется ввести 
информацию или установить альтернативное состояние (значе¬ 
ние). Фиксация установленного состояния (значения) и введенной 
информации осуществляется клавишей Епіег. 

Разрешение (запрет) обновления поля устанавливается 
выбором клавишей Епіег слова Ѵе$ (Ио) в позиции Есііііпд 
аііожесі. Условие для обновления поля вводится в окно, откры¬ 
вающееся после выбора позиции Регтіі есііі іі. В качестве 
условия можно записать любое допустимое выражение для полей 
файла БД. Ввод текста, который будет высвечиваться внизу 
экрана при перемещении курсора в поле (например, для 
пояснения специфики обновления данных) осуществляется 
выбором позиции Медеаде. Установка копирования в поле 
значения из предыдущей записи выполняется выбором слова Ѵе$ 
в позиции Саггу ІопѵагсІ. Начальное значение поля вводится после 
выбора позиции йеіаиіі ѵаіие. Контроль диапазона вводимых 
числовых данных можно осуществить, установив минимально и 
максимально допустимые значения чисел или данных типа даты 
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после выбора позиций 5таІІе$і аііожеб ѵаіие и ^а^де$і аііоѵѵеб 
ѵаіие. Условие для ввода нового значения в поле и сообщение, 
которое будет высвечиваться внизу экрана, можно ввести после 
выбора позиций Ассері ѵаіие жНеп и ІІпассеріесІ тедеаде. 
Сохранение всех данных, относящихся к полю файла БД, 
выполняется клавишами СігІ-ЕпсІ. 

Кроме полей файла БД в экранную форму можно вводить 
вычисляемые поля. Меню для создания вычисляемого поля 
высвечивается после выбора позиции <сгеаіе> под заголовком 
СА1.СШ.АТЕ0 в таблице из двух колонок, появляющейся в 
результате выбора позиции АсІсІ (іеІсЬ меню Ріеісіз. В этом меню 
после выбору позиции Ыате надо задать имя вычисляемого поля, 
после выбора позиции Оезсгірііоп можно ввести с клавиатуры 
словесное описание вычисляемого поля и обязательно после 
выбора позиции Ехрге$$іоп надо ввести выражение, определяю¬ 
щее вычисляемое поле. В этом выражении можно использовать 
все допустимые операторы применительно к соответствующим 
полям файла БД. Нельзя в выражении указывать ранее создан¬ 
ные вычисляемые поля. Для вычисляемого поля можно устано¬ 
вить шаблон и функции поля. Знаки шаблона вычисляемого поля 
не отличаются от знаков шаблона обычного числового поля. В 
состав функций, которые могут использоваться для вычисляемого 
поля, входят две ранее описанные функции - ! и К, а также 
новые функции: 

Т - удаление ведущих и конечных пробелов; 

\ - выравнивание содержимого поля вправо; 

I - центровка содержимого поля. 

Кроме обычных полей в экранную форму можно включать 
переменные. Значения переменных вводятся с клавиатуры и 
могут использоваться для различных операций с данными из 
полей файла БД. Это существенно расширяет возможности по 
обработке информации с помощью экранной формы. Для ввода 
в экранную форму переменной служит позиция Іп$егі тетогу 
ѵагіаЫе. Тип переменной определяется выбором из альтернатив¬ 
ных значений клавишей Пробел. Кроме типа переменной после 
выбора соответствующей позиции следует также ввести имя 
переменной (Нате), шаблон поля переменной (Тетріаіе), 
функции поля (Рісіиге Іипсііоп) и опции редактирования поля 
переменной (ЕсШ орііопх). Эти данные вводятся аналогично 
обычным полям файла БД. Как и для обычных полей, после 
ввода параметров переменной их надо сохранить клавишами 
СігІ-ЕпсІ. После этого поле переменной появляется в том месте, 
где расположен курсор. Поле переменной, как и другие поля, 
можно перемещать в любое место экрана по общим правилам 
перемещения полей. 

мри разработке экранной формы в нее кроме полей и 
текстового материала можно вводить оформительские элементы, 
например рамки, полоски, расцвечивать различные области экрана 
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и т.д. Один такой элемент уже рассматривался выше - рамки 
для полей типа Мето. В меню І.ауоиі имеются позиции для 
рисования рамок (Вох) И линий (Ипе) на экране вокруг других 
полей или текстового материала. После выбора позиции Вох 
высвечивается окно для выбора трех типов линий, как и для 
рамки поля Мето. Рисование рамки осуществляется аналогично 
формированию окна поля Мето. Более широкие возможности 
для рисования на экране обеспечивает позиция 8-іпе, позволяю¬ 
щая делать рисунки из отрезков горизонтальных и вертикальных 
линий. Эти линии можно прервать для записи текста, а затем 
вновь продолжить. Действия по рисованию линий выполняются 
аналогично формированию рамки, т.е. сначала нужно зафиксиро¬ 
вать клавишей Епіег начало линии, затем нарисовать линию, 
набрать текст и завершить рисование также нажатием клавиши 
ЕпТег. Если что-то не получается с линиями, например, не 
сходятся концы и т.п., лучше всего прервать рисование клавишей 
Епіег, затем удалить ненужные элементы клавишами ЭеІ или 
Васісзрасе и затем начать рисование с прерванной точки. 

В экранной форме можно размещать поля, оформительские 
элементы и текстовый материал, выходящие за границы стандарт¬ 
ного экрана. Размер экранной формы ограничен только емкостью 
свободной оперативной памятью ПК. Для удобства работы с 
многостраничными экранными формами имеются меню У^огсіз и 
Соіо. С помощью меню Ѵ/ог4* можно устанавливать различный 
цвет полей, рамок и других областей экрана, позиционировать 
текст, изменять разметку экранной формы в верхней части 
экрана или удалять ее, добавлять или удалять строку текста, 
вводить текстовый материал в экранную форму из других 
файлов и записывать текст экранной формы во внешний 
текстовой файл. Меню Соіо позволяет быстро перемещаться по 
строкам экранной формы, осуществлять поиск и заменять слова. 

Для расцвечивания областей экранной формы используется 
позиция Різріау меню Ѵ/ог4*. Перед ее выбором необходимо 
высветить клавишей Р6 и навигационными клавишами ту область 
экрана, которую требуется закрасить. Установка цвета области 
выполняется передвижением курсора по цветовой гамме палитры 
для фона (Васкдгоипе!) и текста (РогедгоипеІ). 

Позиционирование текста выполняется выбором опции 
Розіііоп меню >Л^огсІ$. После этого появляется меню с позициями: 
І-еЙ - высвеченный участок текста передвигается в левый край, 
КідМ - в правый край, Сепіег - центрируется. 

Удаление разметки экрана выполняется выбором позиции 
Нісіе гиіег, а ее изменение - выбором позиции Мосіііу гиіег. 
Добавление строки в месте расположения курсора осуществля¬ 
ется позицией АсЗсІ Ііпе, а удаление - -озч >ей Кетоѵе Ііпе 
меню Ѵ/ог4$. Более подробно о позициях кюе гиіег и Мосіііу 
гиіег будет сказано в разделе разработки форм отчетов. 
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Ввод (вывод) текста из внешнего файла (во внешний 
файл), начиная с текущей позиции курсора, выполняется выбором 
позиции М^гііе/геасІ іехі ЯІе. После этого появляется меню с 
позициями УЫгііе зеіесііоп іо Іііе для записи во внешний файл и 
Кеасі іехі (гот Іііе для считывания в экранную форму из 
внешнего файла. В обоих случаях в высветившемся окне 
необходимо набрать с клавиатуры имя внешнего файла или 
выбрать его из директориев дисков, высвечиваемых клавишами 
5ЫЙ-Р1. 

В меню Соіо позиция Соіо Ііпе питЬег служит для перехода 
на строку с заданным номером, который нужно ввести с 
клавиатуры. Для поиска слова (или части слова по включению) 
используются позиции РогжагсІ зеагсЬ (поиск в прямом направле¬ 
нии) и ВаскжагсІ зеагсЬ (поиск в обратном направлении). После 
выбора позиции с клавиатуры нужно ввести искомое слово (или 
часть слова - поиск по включению), после чего поиск инициали¬ 
зируется клавишей Епіег. Замена слов в тексте осуществляется 
позицией Керіасе. Эта операция выполняется совместно с 
поиском. Сначала требуется ввести старое слово, затем новое 
слово. После того как найдено первое встреченное заменяемое 
слово, пользователю на выбор представляются варианты замены 
(для этого надо ввести с клавиатуры соответствующую букву): 
заменить одно слово - К, пропустить одно слово - $, заменить 
все слова в тексте - А, отменить замену - клавишей Езс. При 
поиске слов можно задать условие не различать (или различать) 
прописные и строчные буквы с помощью установки значений ОРР 
(ОМ) в позицию МаісН сарііаііхаііоп. 

После ввода всей информации по созданию экранной формы 
ее нужно сохранить на диске с помощью позиции 5аѵе іНіз іогт 
для последующего повторного использования. Перед сохранением 
экранной формы ей нужно с клавиатуры присвоить имя в окне 
$аѵе аз: по форме имя дискаДмаршрут по директориям\имя 
экранной формы, например, й :\ЬВА$Е1Ѵ\РКІМЕК\МР1. 

Для идентификации созданной экранной формы можно 
ввести ее словесное описание с помощью позиции Есііі 
сіезсгірііоп оі іЬе іогт. Это словесное описание будет высвечи¬ 
ваться при выборе формы в окне Рогѵпз панели УЦ. Сохранение 
экранной формы можно также выполнить перед выходом в УЦ 
с помощью позиции §аѵе сііапдез апсі ехіі меню Ехіі. В этом 
случае, если данная форма ранее уже была записана на диск, то 
окно с этим именем не высвечивается и осуществляется переза¬ 
пись новой формы на старую с тем же именем. Позиция 
АЬапсІоп сНапдез апсі ехіі служит для выхода в УЦ без сохране¬ 
ния разработанной формы. 

Более короткий способ высвечивания созданной экранной 
формы без покидания экрана создания/модификации экранной 
формы реализуется нажатием клавиши Р2. Возврат к экрану 
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создания/модификации формы выполняется клавишами 5МК-Р2 
или выбором позиции Кеіигп іо Рогт йезідп меню Ехіі. 

Запуск экранной формы можно также осуществить с панели 
УЦ. После выбора имени экранной формы высвечивается меню 
с позициями Мосіііу Іогіш для перехода к изменению экранной 
формы, йізріау сіаіа для высвечивания экранной формы. 

Продемонстрируем теперь, как создать простую экранную 
форму, показанную на рис. 2.4. Откройте файл МІДО1. Установите 
курсор на позицию <сгеаіе> в окне Рогт$ и нажмите клавишу 
Епіег. Высветится экран создания/модификации экранной формы. 
После входа в экран создания/модификации экранной формы 
автоматически активизируется вертикальное меню, прикрепленное 
к позиции Ьауоиі горизонтального меню. Выберите позицию 
Оиіск І_ауоиі и нажмите Епіег. Слева на экран в столбик 
выведутся все поля файла МЕШ1. 

Теперь расположите поля на экране, например так, как 
показано на рис. 2.4. Перед перемещением любого поля (кроме 
поля типа Мето, размещение которого описано ниже) надо 
установить на него курсор, нажать клавишу Р6 Г затем клавишу Р7, 
переместить курсор в нужное место и нажать Епіег. При 
перемещении полей в нижней части экрана может высвечиваться 
сообщение: Реіеіе соѵегесі іехі апсі ііеІсіз (У/И) ?, означающее, 

что на новом месте уже что-то находится, например, часть этого 
же поля. Для подтверждения перемещения нажмите клавишу V. 


1_ауои1 Ріеігіз Ѵоггіз 6о То ЕхП 12:53:39 рш 

Для выхода в меню нажмите клавишу ПО 

Табельный номер 9999 

Фамилия Имя Отчество Дата рохд. 

[ ХХХХХХХХХХХХХХХ ХХХХХХХХХХХХХХХ ХХХХХХХХХХХХХХХ ОР/ММ/УУ ] 

Стах работы водителем (лет) - 99 

Категория водительских прав - ХХХХХХХХХХХ 

Номерной знак автомобиля - ХХ-ХХ XXX 

АВТОБИОГРАФИЯ 


хххххххххххххххххххххххххххххххххххххххххххххххххххххххххххххххх 
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Рогт |С:\сІЬазе\МР1 |Кои:0 Со 1:0 |Р11е:МЬгі1 I Іпз 

АсісІ ііеісі: Р5 $е1есі:Р6 Моѵе:Р7 Сору:Р8 $І2е:$Н1П-Р7 


Рис. 2.4. Экранная форма данных о водителях. 
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Как уже упоминалось, поля типа Мето можно представить 
на экране в форме окна и в скрытом виде, когда высвечивается 
только маркер этого поля - слово МЕМО. Опишем, как размес¬ 
тить поле Мето АІІТО в оконной форме. Для этого установите 
на него курсор и выберите позицию МосІіТу (іеісіз меню Ріеісіз. 
В высветившемся меню установите курсор на позицию Різріау а* 
и клавишей Пробел выберите опцию \УІНООѴЛ Затем выберите 
позицию Ебіі орііопз этого же меню и установите значение 
опции ЕсШіпд аііоѵѵесі - Ѵе$ для разрешения редактирования 
этого поля Мето и нажмите клавиши СігІ-ЕпсІ дважды. В 
результате появится окно Мето поля стандартных размеров. Для 
приведения окна к нужным размерам установите курсор на 
рамку окна, после чего окно подсветится. Далее нажмите 
клавиши 5ЫН-Р7 и навигационными клавишами (Вправо, Влево, 
Вверх) установите требуемые размеры окна и нажмите клавишу 
Епіег. Для перемещения окна в нужное место экрана нажмите 
клавишу Р7 и передвиньте окно навигационными клавишами, не 
забыв зафиксировать новое положение клавишей Епіег. 

Сделайте пояснительные надписи к полям. Для акцентирова¬ 
ния полей можно их обвести рамкой. Для этого выберите 
позицию І-іпе меню Ьауоиі, а в высветившемся при этом 
вертикальном меню - позицию Біпдіе Ііпе. Установите курсор на 
нужную позицию экрана и нажмите клавишу Епіег. Начальная 
позиция линии зафиксирована. Затем навигационными клавишами 
нарисуйте рамку. После окончания рисования не забудьте 
зафиксировать ее клавишей Епіег. Если при рисовании рамок и 
линий сразу не удастся сделать требуемый рисунок (например, 
не совпало начало линии с концом), то завершите рисование, 
удалите ненужные отрезки прямых клавишами Ое! или Васкзрасе 
и начните рисование с прерванной точки. После завершения 
оформления полей на новом месте сотрите уже ненужные 
теперь имена этих полей ЫОМ, РАМ, ЫАМ, ОТС, Р_К, остав¬ 
шиеся на прежнем месте. 

Для обеспечения более полной информации о содержании 
полей экранной формы можно предусмотреть высвечивание 
сообщения внизу экрана при перемещении курсора на поле. 
Например, для поля ЫОМ введите сообщение: "Служит иденти¬ 
фикатором водителя". Для этого сначала выберите позицию 
МосШу РіеІсІ меню Ріеісіз, после чего высветится список полей, 
из которого выберите поле ИОМ. Затем в высветившемся меню 
выберите позицию Есііі орііопз. После этого появится еще одно 
вертикальное меню, в котором выберите позицию Ме$$аде и 
введите этот текст. Введенный текст надо зафиксировать 
клавишей Епіег и затем сохранить клавишами СЫ-ЕпсІ. Чтобы 
выйти из меню нажмите еще раз СН-Епв, что означает сохране¬ 
ние введенных в этом меню данных. 

Шаблоны полей играют важную роль при вводе данных. Они 
позволяют сократить количество вводимых вручную символов, 
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организовать контроль ввода и обеспечить наглядность вывода 
данных. Например, в шаблоне поля ЫОМ задайте функцию 
вывода ведущих нулей, поскольку по умолчанию устанавливается 
шаблон обычного числа. Для этого переместите курсор на поле 
ИОМ, выберите позицию Мосіііу РіеМ меню Ріеісіз, в высветив¬ 
шемся меню - позицию РісКіге Іипсііопз, а затем в следующем 
меню - опцию $Нож Іеасііпд іегоез, в которой с помощью 
клавиши Пробел установите слово ОЫ. Для завершения установки 
нажмите два раза клавиши СІгІ-ЕпсІ. 

Аналогично для полей РАМ, МАМ, ОТС установите функцию 
запрета на ввод чисел в поле. Для этого в высветившемся меню 
после выбора позиции Рісіиге іипсНопз меню переведите 
позицию АІрНаЬеііс сНагасіегз опіу в ОИ-состояние клавишей Епіег 
и затем нажмите два раза клавиши ОгІ-Еп 6. 

Контроль ввода данных можно установить с помощью 
запрета ввода определенных значений. Например, требуется 
запретить ввод данных на водителей старше 55 и моложе 20 лет. 
Для этого переместите курсор на поле й__Р и нажмите Р5 в 
качестве короткого выхода на модификацию установок поля. 
Выберите позицию Есііі орііопз, а в высветившемся вертикальном 
меню позицию Ассері ѵаіие жНеп, и введите условие 

>= ОАТЕП - 55*365 .АИй. Р_Р < = ОАТЕ() - 20*365 

где функция ОАТЕП возвращает текущую дату. 

Чтобы при вводе в поле 0_В даты,, не удовлетворяющей 
заданному диапазону значений, высвечивалось сообщение, 
выберите опцию ІІпассеріесІ теззаде, введите текст "Не подходит 
по возрасту!". 

Для облегчения процесса ввода данных целесообразно в 
шаблон помещать повторяющиеся символы. Например, при вводе 
номерных знаков автомобиля в поле каждой записи можно 

ввести разделитель цифр номерного знака и пробел, отделяю¬ 
щий цифровую и символьную части номера. Для этого измените 
шаблон ввода-вывода данных поля И_2. Вместо третьего 
символа шаблона "X" введите а вместо шестого символа 

"X" - пробел и затем нажмите клавиши Епіег и СМ-ЕпсІ. После 
выполненных изменений шаблон поля будет выглядеть так: 

ХХ-ХХ XXX'. Теперь при вводе с клавиатуры номерного знака 
пользователю не нужно ставить разделитель цифр и пробел 
между буквами и цифрами, они будут вводиться автоматически. 

Экран можно раскрасить в различные цвета. Для этого с 
помощью клавиши Р6 и навигационных клавиш высветите ту 
область экрана, которую необходимо раскрасить. Затем выберите 
позицию Оізріау меню >ѴогсІ5 и из палитры цветов подберите 
требуемые цвета текста и фона. После выбора цветов не 
забудьте зафиксировать их клавишами СІтІ-ЕпсІ . 

Создание экранной формы в основном закончено. Можно 
лишь порекомендовать в левой части верхней строки экранной 
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формы ввести текст сообщения о том, как вызвать меню 
экранной формы, чтобы выйти в УЦ, например: "Для выхода в 
меню нажмите клавишу РІО". 

Для идентификации экранной формы можно ввести ее 
описание, которое будет высвечиваться в нижней строке УЦ при 
установке курсора на имя формы. Для этого выберите позицию 
Есііі 4е$сгірііоп о( іогт меню І.ауоиі и введите словесное 
описание формы. Сохранение файла экранной формы на диске 
можно выполнить выбором позиции $аѵе !Ні$ (огт меню І.ауоиі 
или позиции $аѵе сНапдез ап<1 ехіі меню Ехіі. 

После выбора позиции для сохранения формы высвечивается 
окно $аѵе аз, в которое нужно ввести имя формы после имени 
диска и маршрута по директориям, например, 0:\0ВА5ЕІѴ\ 
РКІМЕК\МР1, и нажать клавишу Епіег, после чего созданная 
экранная форма будет записана на диск. 

Заметим, что если экранная форма ранее уже записывалась 
с помощью позиции $аѵе іЬіз Іогт меню І.ауои1, то после выбора 
$аѵе сНапдез апс! ехіі меню Ехіі уже не будет высвечиваться 
окно с предложением ввести имя. При сохранении с помощью 
позиции меню І.ауоиі окно для ввода имени высвечивается 
всегда, что можно использовать для записи копии разработанной 
экранной формы под другим именем. 

Запуск экранной формы из УЦ осуществляется нажатием Р2 
после установки курсора на имя экранной формы или нажатием 
Епіег и выбором позиции Різріау сіаіа в высветившемся горизон¬ 
тальном меню. Причем если в УЦ открыт файл БД, не связанный 
с данной формой, то высвечивается горизонтальное меню с 
двумя позициями: Сиггепі ѵіеж (текущая выборка) и имя файла 
БД или выборки, связанной с вызываемой формой. 

В нашем учебном примере каждая экранная форма связана 
с определенным файлом БД, имя которого и высвечивается. 
Поэтому нужно перейти на это имя и нажать клавишу Епіег. 

Переход по полям в высветившейся экранной форме 
производится навигационными клавишами Вверх, Вниз, а переход 
на следующую и предыдущую запись клавишами РдЦр и РдОп. 
В прямом направлении по полям можно также передвигаться 
клавишами ТаЬ и Епіег, а в обратном - клавишами $Ьііі-ТаЬ. 

Заметим, что после перемещения курсора на Мето поле ре¬ 
дактировать данные в нем еще нельзя. Режим редактирования 
Мето поля активизируется клавишами Сііі-Ноте. Выход из 
режима редактирования осуществляется клавишами СігІ-ЕпсІ. Для 
выхода из режима высвечивания экранной формы, нужно 
активизировать меню клавишей РІО, в котором следует восполь¬ 
зоваться позицией Ехіі. 

Для закрепления полученных навыков попробуйте самостоя¬ 
тельно создать экранные формы ввода и вывода данных из 
файлов МВ02, МВРЗ, МВР4. 
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В учебных примерах этим экранным формам присвоены 
имена МР2, МРЗ и МР4, а их вид показан на рис. 2.5-2.7. 


Ьауои* Ріеігіз Уогбз бо То ЕхН 12:54:38 рш 

Для выхода в меню нажмите клавишу РІО 


Автомобиль: ХХХХХХХХХХ номерной знак: ХХХХХХХХХ 

Техническое состояние: ХХХХХХХХХХХХ 

Где находится в данное время: ХХХХХХХХХХХХ 


Рогт |С: ѴсІЬазеѴрг 1тег\МР2 |Кон:0 Со 1:0 |Р11е:МВ02 | Іпз 

АсІсІ Т1е1сі:Р5 5е1ес1::Р6 Моѵе:Р7 Сору:Р8 5І2е:$МП-Р7 


Рис. 2.5. Экранная форма данных о состоянии автомобилей 


1_ауои* Ріеісіз Ыогсіз 6о То Ехіѣ 2:55:16 рш 

Для выхода в меню нажмите клавишу РІО 

Наименование груза: ХХХХХХХХХХХХХХХХХХХХ Вес - 99.9 т. 
Номерной знак автомобиля, перевозящего груз: ХХХХХХХХХ 


Исходный пункт: ХХХХХХХХХХХХХХХ Дата выезда: 00/ММ/УУ 
Конечный пункт: ХХХХХХХХХХХХХХХ Дата прибытия: 00/ММ/УУ 


Расстояние: 9999 км Время в пути (фактич.): 999 ч 

Расход горючего (фактич.): 9999.99 

Рогт |С:\гіЬазе\ргітег\МРЗ |Ком:0 Соі:0 |Р11е:МВ03 | Іпз 

Асіа Тіе1сі:Р5 ЗеІес^Рб Моѵе:Р7 Сору:Р8 $іге:5Ніті-Р7 


Рис. 2.6. Экранная форма данных о перевозках 
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1_ауои* Ріеісіз Ѵоггіз 6о То Ехіі 12:55:48 рш 

Для выхода в меню нажмите клавишу ПО 


Технические характеристики 

Марка: ХХХХХХХХХХ 
Скорость: 999 км/ч 
Грузоподъемность: 99.9 т 
Расход топлива на 100 км : 999.99 л 


Рогт |С:\с!Ьазе\ргітег\МР4 |Коѵ*:0 Со 1:0 |Рі1е:МВ04 | Іпз 
Адд Гіеісі:Р5 5е1ес1:Р6 Моѵе:Р7 Сору:Р8 $іге:$ИіП-Р7 


Рис. 2.7. Экранная форма технических характеристик автомобилей 


2.7. РАЗРАБОТКА ОТЧЕТОВ 

Разработка отчетов наряду с экранными формами является 
завершающим этапом подготовки технологии обработки инфор¬ 
мации. При выдаче отчетов могут использоваться выборки 
данных, полученные в результате выполнения запросов, и 
исходные файлы БД. В итоге разработки отчета создается 
(генерируется) программный файл, который выполняется при 
выводе отчета. При выполнении программного файла отчета 
осуществляется извлечение данных, представление их в форме, 
требуемой для вывода на печать, и посылка символов и 
управляющих кодов на печатающее устройство. 

Каждому отчету (программному файлу) присваивается имя, 
выбрав чоторое в окне отчетов на панели УЦ, можно распеча¬ 
тать отчет на принтере, вывести эго на экран или в текстовый 
файл на диск. Программный файл отчета позволяет выполнять 
не только собственно операции по форматированию отчета, но 
и ряд предварительных операций по обработке данных. 
Например, можно задать условия для отбора требуемых записей 
файла БД в отчет и выполнить арифметические действия, как 
это делается с помощью запросов. Кроме этого, при подготовке 
отчетов можно выполнять более сложные операции, не 
предусмотренные в запросах: агрегирование, статистическую 





информации и др. Таким образом, отчет является весьма 
мощным средством не только форматирования, но и многоплано¬ 
вой обработки информации. В нем объединяются функции 
выполнения запросов на отбор информации, ее преобразования 
и представления в удобной форме для анализа. 

Разработка отчета выполняется в окне &ерогі$ УЦ. Вход в 
экран разработки отчетов из УЦ осуществляется выбором 
позиции <сгеаіе> в окне Керогіх. Предварительно необходимо 
активизировать файл БД или выборку, которые будут использо¬ 
ваться в отчете. Если требуется модифицировать уже созданный 
программный файл отчета, сначала надо выбрать его имя в окне 
Керогіз и затем позицию МосііІу Іауоиі в высветившемся меню. 
Короткий способ выхода на экран разработки отчета реализуется 
клавишами 5ЫК-Г2 после предварительной установки курсора на 
имя отчета. 

Форма отчета создается на экране. В нее можно включать 
следующие элементы: поля из текущего файла БД или выборки, 
вычисляемые поля, которые создаются специально для отчета, 
текстовый материал, рамки и линии. Текст длинных символьных 
полей можно размещать и разворачивать в колонках заданной 
ширины. 

Экран разработки отчета состоит из горизонтальных полос. 
Эти полосы разделяют отчет на составные части. В число 
стандартных частей входят: заголовок страницы, введение 
(заголовок) отчета, тело отчета, итоги (заключение) отчета и 
подножие страницы. Тело отчета формируется в одной полосе. 
Остальные части отчета представляются в экранной форме 
парами: заголовок страницы - подножие страницы, введение 
отчета - итоги отчета. 

Кроме указанных элементов можно добавлять полосы, 
объединяющие записи в группы по номеру записи, значению 
поля или по выражению, включающему поля файла БД, вычис¬ 
ляемые поля и специальные поля, функции и операторы. 
Например, в файле адресов места жительства можно объединять 
каждые N записей, создавать группы записей лиц с одинаковым 
местом жительства или группы с одинаковыми первыми тремя 
цифрами почтового индекса. Каждая группа включает пару 
полос - введение (заголовок) группы и итоги (заключение) 
группы. 

Группирование записей обычно применяется для отсортиро¬ 
ванных или индексированных файлов БД. Группирование часто 
используется для получения промежуточных итогов, вычисления 
статистических функций: усреднения, подсчета количества записей, 
определения максимального и минимального значений, подсчета 
сумм, расчета среднеквадратического отклонеми* и дисперс* 

При разработке отчета используются два режима. Режим 
развертки текста и режим размещения элементов отчета, 
которые включают поля, рамки, линии и другие оформительские 
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элементы (для краткости этот режим будем называть режимом 
размещения полей). 

Первый режим похож на обычный текстовый редактор и 
позволяет вводить текст непрерывной строкой, который развора¬ 
чивается по вертикали в заданных границах. При правках текста 
в этом режиме на место удаленного слова или предложения 
будет подтягиваться текст, расположенный справа, а вставленное 
слово или предложение будет раздвигать текст вправо. Этот 
режим может использоваться для создания введения или 
заключения к отчету и ввода других текстовых материалов. 

Режим размещения полей позволяет расположить в нужные 
места на экране разработки отчета обычные и вычисляемые поля 
файла БД. В этом режиме также можно вводить текст, но при 
удалении или вставке слова или предложения текст справа не 
передвигается. Признаком режима размещения полей на экране 
служит мелкая сетка. Если экран чистый, то это признак режима 
развертки текста. Мелкая сетка на экране в режиме размещения 
элементов является не только признаком режима, но и несет, 
как и при разработке экранных форм, служебную функцию - 
обозначает, что экран пустой (на нем нет ни символов, ни 
пробелов). Ввод пробелов приводит к очистке от сетки области 
экрана. Как и при выводе полей в экранной форме, вывод на 
печать полей, находящихся в очищенной области, отличается от 
вывода на печать, когда они разделены мелкой сеткой. В первом 
случае, при выводе на печать значения полей прижимаются друг 
к другу (между ними оставляется только один пробел), а во 
втором они остаются в фиксированных положениях в соответ¬ 
ствии с длиной полей, определенных в файле БД. Для перехода 
в режим развертки текста нужно выбрать значение Ѵе$ в 
позиции У/огб ум г ар ЬапсІ меню Вапсіз, а для выхода из него - 
значение Ио. 

В верхней части экрана разработки отчетов имеется семь 
меню: І.ауоиІ, Ріеісіз, Вапсй, >ѴогсІ$, Соіо, Ргіпі и Ехіі Меню 
І.ауоиі предназначено для быстрого размещения на экране 
разработки отчета всех полей файла БД в стандартных формах, 
рисования рамок и линий, ввода словесного описания отчета, 
присоединения к отчету файла БД, отличного от активного в 
текущий момент, и сохранения программного файла отчета на 
диске. 

Для ввода в форму отчета только требуемых полей 
используется меню РіеІсІ$. Меню ВапсІ$ позволяет создавать и 
удалять полосы, предназначенные для вывода групп данных, а 
также назначать каждой полосе свои опции печати. 

С помощью меню \УогсІ$ и Соіо можно позиционировать 
текст, добавлять и удалять строки, вводить текст из внешних 
текстовых файлов, передвигаться по разрабатываемой форме 
отчета, замещать слова и т.д. 
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Меню Ргіпі предназначено для установки опций печати 
выходного документа в целом, указания вывода отчета на 
принтер, экран, внешний текстовый файл, установки посылки на 
принтер управляющих кодов и т.д., а меню Ехіі для выхода из 
окна разработки отчета. 

Если в форму отчета должны входить группы, то целесооб¬ 
разно начать разработку с определения состава групп, для чего 
предназначено меню ВапсЬ. Для ввода на экране пары полос 
группы выбирается позиция АсІсІ дгоир Ьапсі этого меню. 
Предварительно курсор должен быть установлен выше тела 
отчета на полосе заголовка страницы (Іпіго Раде ВапсІ), 
заголовка отчета (Іпіго Керогі ВапсІ) или на полосе уже 
существующей группы (бгоир N Іпіго ВапсІ, где N - номер 
группы). После этого нужно выбрать тип группы из высветив¬ 
шегося меню: по значению поля - РіѳІсІ ѵаіие, по выражению 

- Ехргедеіоп ѵаіие и по количеству записей - КесогсІ соипі. 

При выборе позиции РіеІсІ ѵаіие высвечивается список полей 
из файла БД, а также вычисляемые поля, ранее определенные 
для данного отчета. Выбранное поле используется в качестве 
группирующего признака. 

При выборе типа группы Ехргеззіоп ѵаіие требуется ввести 
выражение для определения группы. Можно использовать 
клавиши 5МК-Р1 для выбора имен полей, операторов или 
функций из высвечиваемого списка, а также вводить выражение 
непосредственно с клавиатуры. 

При выборе типа группы КесогсІ соипі требуется ввести 
число записей, определяющих группу. 

В отчет можно ввести несколько групп, которые будут 
вложенными. Созданные полосы групп нумеруются. Нумерация 
групп соответствует уровню вложенности (не зависит от порядка 
создания группы, а только от ее положения по отношению к 
другим группам). При печати отчета с группами сначала выво¬ 
дится внешняя группа данных (с номером 1). Внутри этой 
группы выводятся группы следующего уровня вложения и т.д. 
Тип группы высвечивается внизу экрана при установке курсора 
на соответствующую полосу. 

Для удаления группы используется позиция Кетоѵе дгоир. 
При этом удаляется текущая группа, на которую установлен 
курсор, включая обе полосы, входящие в состав группы - 
введение группы и ее итоги. Группы, вложенные внутри текущей 
группы, не удаляются. Для удаления можно также использовать 
клавишу РеІ. 

Если требуется изменить тип группы, то используется 
позиция Мосіііу дгоир. При этом высвечивается меню типов 
группы, что позволяет изменять тип группы или значения 
(выражения), использованные для формирования групп. 

При формировании отчетов с большим числом групп для 
удобства работы может потребоваться скрыть содержимое всех 
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групп, за исключением текущей разрабатываемой группы. 
Содержимое группы скрывается клавишей Епіег при установке 
курсора на верхнюю полосу группы. Для того чтобы быстро 
открыть содержимое всех групп, используется позиция Орел аІІ 
ЬапсЬ. 

Остальные позиции меню Вап4$ позволяют установить опции 
печати специально для текущей группы. Выбор позиции Сгоир, 
іпіго оп еасН раде дает возможность выводить заголовок группы 
на каждой странице, пока продолжается данная группа. Эта 
позиция используется, например, для вывода заголовка длинных 
таблиц, печатаемых на нескольких страницах. 

Для печати новой группы с начала страницы применяется 
позиция Ведіп Ьапсі оп пеж раде. Позиция Тех! ріісЬ (ог Ьапсі 
позволяет выбрать тип шрифта: РІСЛ (обычный - 10 символов 
на дюйм), БЫТЕ (уменьшенный - 12 символов на дюйм), 

СОНОЕИЗЕО (сжатый), ОЕРАШ.Т (установленный в меню Ргіпі). 
Качество печати устанавливается позицией Оиаіііу ргіпі Іог Ьапсі: 
качественная - УЕ5, обычная - НО или установленная в меню 
РгіпІ - ОЕРАШ.Т. Межстрочный интервал выбирается позицией 
$расіпд оі ІІПѲ5 Іог Ьапсі: 5ІИСІ.Е (через одну строку), ООІІВІ.Е 
(через две строки), ТКІРІ.Е (через три строки), ОЕРАІЛ.Т 
(установленный в меню Ргіпі). 

Для того чтобы не печатать заголовок и подножие страницы, 
во введении и итогах отчета выбирается значение Ыо в позиции 
Раде Ьеасііпдз іп герогі іпіго. 

После формирования групп в отчете можно вводить поля. 
Для ввода полей можно использовать позицию Оиіск Іауоиі, 
позволяющую ввести все поля файла БД в виде трех стандарт¬ 
ных типов отчетов: 

типа экранной формы Вгоѵ/$е (Соіитп Іауоиі) - все поля БД 
располагаются горизонтально до 255 позиций в ширину. Если все 
поля не умещаются, то высвечивается сообщение об ошибке и 
оставшиеся поля отбрасываются, 

типа экранной формы Есііі (Рогт Ьауоиг) - поля располага¬ 
ются по вертикали. Полоса введения отчета закрывается. Номер 
страницы и дата располагаются в полосе заголовка страницы; 

типа письма (Маіітегде Іауоиі) - все полосы за исключе¬ 
нием тела отчета закрываются. Устанавливается режим развертки 
текста и печати полосы на новой странице, что позволяет 
вводить текстовый материал и печатать каждую запись файла БД 
на новой странице. 

Поля можно перемещать и копировать на экране с помощью 
клавиш Р7 и Р8. Предварительно следует установить курсор в 
поле и высветить его клавишей Р6. После этого нужно перемес¬ 
тить курсор на новое место и нажать клавишу Р7 (Р8) для 
перемещения (копирования) поля и затем зафиксировать 
перемещение клавишей Епіег. Размер поля можно изменить 
клавишами 5НІЙ-Р7 также после высвечивания поля. После 
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изменения размера навигационными клавишами Вправо и Влево 
следует также зафиксировать новый размер клавишей Епіег. 

Основным способом ввода в форму отчета всех типов полей 
служит позиция Асісі (іеісі меню Ріеісіз или для более короткого 
ввода - клавиша Р5. После этого высвечивается таблица, состоя¬ 
щая из четырех колонок. В первой колонке содержатся имена 
полей текущего файла БД (выборки). В случае использования 
выборки в число полей включаются и вычисляемые поля, 
созданные в этой выборке. Вторая колонка содержит имена 
новых вычисляемых полей, которые включаются в отчет. Третья 
колонка содержит имена системных полей: йаіе (текущая дата), 
Тіте (текущее время), Кеспо (номер записи), и Радело 
(страница), которые могут использоваться в отчете. Четвертая 
колонка содержит имена операторов агрегирования и статистичес¬ 
ких функций: Аѵегаде (среднее значение), Соипі (количество 
записей), Мах (максимальное значение), Міп (минимальное 
значение), $ит (сумма), $іс! (среднеквадратическое отклонение) 
и Ѵаг (дисперсия). Эти операторы используются для создания 
полей в полосах итогов (подытогов) отчета, в которые помеща¬ 
ются результаты агрегирования. 

После выбора имени поля файла БД в таблице высвечивается 
меню, в котором описано это поле и содержатся три позиции: 
Тетріаіе - для ввода знаков шаблона поля, Рісіиге іипсііоп - для 
установки функций поля, Зиргезз гереаіесі ѵаІие$ ѴЕ$ 
(N0) -для подавления (вывода) повторяющихся значений поля. 
Знаки шаблона для различных типов полей, применяемые при 
разработке отчетов, ничем не отличаются от используемых для 
экранных форм и описаны в разделе разработки экранных форм. 
Функции поля, предназначенные для печати, несколько отличают¬ 
ся от функций, применяемых для экранных форм. Для числовых 
полей используются следующие функции: 

С - аббревиатура СК (кредит) после положительного числа; 

X - аббревиатура ОВ (дебет) после отрицательного числа; 

( - отрицательное число в круглых скобках; 

I. - печать ведущих нулей числа; 

2 - пробелы вместо ведущих нулей числа; 

$ - знак валюты впереди числа; 

^ - формат числа с порядком (научная запись числа); 

Т - удаление ведущих и конечных пробелов; 

В - выравнивание влево; 

I - центрирование; 

V - вертикальная развертка по шаблону поля. 

Для символьных полей применяются функции: 

! - преобразование строчных букв в прописные; 

Л - печать заданных символов; 

Т - удаление ведущих и конечных пробелов; 

I - выравнивание вправо; 

I - центрирование; 


89 



У - вертикальная развертка по шаблону поля; 

; - вертикальная развертка по признаку. 

Как и при разработке экранной формы, функции поля 
устанавливаются выбором значения Ѵе$ для соответствующей 
функции. После установки требуемых знаков шаблонов и 
функций поля их необходимо сохранить клавишами СігІ-ЕпсІ. 

Для создания нового вычисляемого поля требуется выбрать 
позицию <сгеаіе> в верхней части таблицы. После этого 
высвечивается меню, в позиции которого следует ввести с 
клавиатуры: имя вычисляемого поля (Ыате), словесное описание 
вычисляемого поля (Оелсгірііоп), выражение, определяющее 
вычисляемое поле (Ехрге$$іоп). При записи выражения вычисляе¬ 
мого поля можно выбирать исходные поля файла БД, ранее 
созданные вычисляемые поля, операторы и функции из списка, 
высвечиваемого клавишами 5НІН-Р1, или же вводить выражение 
непосредственно с клавиатуры. В выражениях нельзя использо¬ 
вать системные поля типа даты (Оаіе) и др. После установки 
значений всех позиций требуется их сохранить клавишами 
Ог1-Еп<1. 

Вычисляемое поле можно скрыть и не печатать (например, 
при использовании его только в составе выражения или в других 
целях) выбором значения Ѵе$ в позиции Нісісіеп. 

Для ввода системного поля, типа текущей даты и времени 
его имя выбирается из таблицы. При этом высвечивается меню, 
в позициях которого можно задать установку (Ѵе$) на подавле¬ 
ние повторяющихся значений ($иррге$ гереаіес! ѵЧиез) или 
изменить клавишей Епіег имя системной переменной (Ыате). 

При создании в отчете поля, в которое заносятся результаты 
агрегирования, оператор агрегирования выбирается из таблицы, 
затем в высветившееся меню после выбора позиции Ыате 
вводится имя этого поля. Можно также ввести словесное 
описание выполняемой операции (позиция Оезсгірііоп), поменять 
оператор агрегирования (если это требуется) посредством 
выбора позиции Орегаііоп и затем выбрать с помощью позиции 
РіеЫ іо зиттагіхе оп требуемые поля файла БД из высвечивае¬ 
мого списка, с которыми выполняется операция агрегирования 
(кроме подсчета числа записей), а также с помощью позиции 
Ке$еі еѵегу установить сброс в ноль значения текущего поля 
агрегированной величины после каждой страницы (опция Раде) 
или в конце отчета (опция Керогі). Знаки шаблона и функции 
полей агрегированных величин полностью аналогичны числовым 
и вычисляемым полям. Операторы агрегирования следует 
помещать в тело отчета или в итоговые полосы групп. 

Если в процессе формирования отчета требуется удалить 
какое-либо поле из формы, это можно сделать выбором позиции 
Кетоѵе ІіеІсІ или клавишей РеІ после установки курсора в 
удаляемое поле. 
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Модификация введенного в отчет поля выполняется выбором 
позиции МосШу ІіеІсІ (на экране появляется таблица полей, как 
и при их вводе в отчет) или при установленном на поле курсоре 
клавишами СМ-Ноте или Р5. 

Для того чтобы восстановить скрытое вычисляемое поле или 
поле агрегированной величины (или скрыть его), это поле 
нужно выбрать из списка, высвечиваемого выбором позиции 
СНапде МсМеп ІіеІсІ. При восстановлении поле размещается в 
текущей позиции курсора. 

После того как введены все требуемые поля, можно вводить 
в форму отчета заголовки и подножия страниц, введение и 
заключение и т.д., которые содержат текстовой материал и 
другие оформительские элементы. 

Для рисования рамок и линий используются позиции Вох и 
Ыпе меню Ьауоиі. Их применение описано в разделе разработки 
экранных форм. 

При оформлении полос отчета можно использовать меню 
>ѴогсІ$ и Соіо. Эти меню общие как для разработки отчетов, так 
и для экранных форм. Меню Соіо полностью описано в разделе 
2.6, а меню >Ѵогс!$ - за исключением позиций, которые там не 
используются. Эти позиции относятся только к разработке форм 
отчетов. Ниже будут описаны эти позиции, а также некоторые из 
используемых и в экранной форме, но имеющие специфику 
применения в двух режимах разработки формы отчета. Следует 
отметить, что для разработки форм отчета, в свою очередь, не 
используется позиция Різріау, которая служит для раскраски 
областей экрана. 

К специфическим позициям для разработки форм отчетов 
относится позиция 5+уІе, служащая для формирования стиля 
печати. После выбора этой позиции высвечивается меню с типами 
шрифтов, которые можно установить для выделенных областей 
текста: ИогтаІ - нормальный, ВоМ - жирный, ІІпсІегІіпе - 
подчеркнутый, Ііаііс - наклонный, КаізесІ - приподнятый, 
Ьожегесі - опущенный. 

Позиция ЕпаЫе аиіотаііс іпсіепі ОН (ОРР) включает 
(выключает) автоматический абзац в режиме развертки текста. 
При выборе ОИ действие клавиш ТаЬ и $ЬіЙ-ТаЬ в том случае, 
если курсор находится в начале параграфа, приводит к переуста¬ 
новке левой границы. Если установлено ОРР, то нажатие клавиш 
$ЬіН-ТаЬ передвигает курсор к следующей позиции табуляции. 
Действие клавиши ТаЬ зависит от установки на клавиатуре 
режима "вставки символов" клавишей Іп$. Если режим "вставки 
символов" выключен, то клавишей ТаЬ курсор передвигается к 
следующей позиции табуляции. Если режим "вставки" включен, 
::г? в м»м* ТаЬ вводит в разметку текстового редактора символ 
табуляции, который передвигает курсор к следующей позиции 
табуляции. В режиме развертки текста при передвижении левой 
границы абзац всегда остается в том же относительном положе- 
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нии. Следует отметить, что позиция этого меню Ро$іііоп, 
служащая для позиционирования текста, действует только в 
режиме размещения полей. 

Позиция Іпзеіі раде Ьгеак устанавливает прерывание печати 
страницы на текущей линии в режиме развертки текста, в 
режиме размещения полей она не действует. 

Позиция МосШу гиіег используется в режиме разработки как 
экранных форм, так и отчетов и служит для изменения разметки 
экрана. Эта разметка высвечивается в режиме размещения полей 
и в режиме развертки текста. При разработке экранных форм 
применяется только режим размещения полей. Разметка 
высвечивается в верхней части экрана и включает символы, 
обозначающие левую и правую границы ([ и ]), абзац (#), 
табуляцию (треугольник) и номер колонки. 

Движение по разметке осуществляется курсором или 
клавишей Пробел. Движение вправо и влево по восемь позиций 
можно выполнить клавишами СігІ-вправо и СЫ-влево, а по 
символам табуляции - клавишами ТаЬ и $ЬіН-ТаЬ. Клавиши Епб 
и Ноте передвигают курсор в левую и правую видимую часть 
экрана. При повторном нажатии этих клавиш происходит 
передвижение еще на одну секцию разметки. Установка симво¬ 
лов разметки выполняется соответствующими клавишами, кроме 
знака табуляции, который вводится клавишей !. Удаление 
символов разметки выполняется как в обычном режиме редакти¬ 
рования текста: клавишами РеІ и Васкхрасе. Если в одной 
позиции размещается несколько символов, то высвечивается 
старший по приоритету в соответствии со следующей последова¬ 
тельностью (по убыванию приоритета): граница, абзац, табуляция 
и номер колонки. Сохранение установок выполняется клавишами 
СігІ-Епб. Устанавливаемая позицией МосШу гиіег разметка не 
сохраняется при вызове редактора для редактирования Мето 
полей, программ или текстовых файлов. 

Рассмотрим более подробно действие позиции АсШ Ііпе, 
служащей для добавления новой строки после текущей. В 
режиме развертки текста сначала закрывается текущий параграф 
и курсор передвигается в начало новой строки. 

В режиме размещения полей добавляется новая строка в 
экранную форму и курсор устанавливается в начало этой строки. 
Эта позииия не используется при разработке экранной формы 
марки, так как марка имеет фиксированную высоту и, следова¬ 
тельно, в нее нельзя добавлять новых строк (слл. раздел 2.8). 

Позиция Кетоѵе Ііпе, служащая для удаления текущей 
строки, в режиме развертки текста заменяет текст текущей 
строки пробелами, но не удаляет строку, а в режиме размеще¬ 
ния полей вместе с текстом из формы удаляется и строка. 

Если к разрабатываемой форме отчета требуется присоеди¬ 
нить другой файл БД или выборку, то для этого следует выбрать 
позицию ІІ$е сІіНегепі сІаіаЬазе Ше ог ѵіе\ѵ меню І.ауои1. 
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Словесное описание отчета, которое высвечивается при его 
выборе на панели УЦ, можно ввести с помощью позиции Есііі 
сіезсгірііол о( героѵі этого же меню. Для сохранения созданного 
отчета (программного файла) на диске с присвоением ему 
имени используются такие же позиции, как и для экранных 
форм: $аѵе іНіз героіі - сохранение без выхода из экрана 
разработки, Ехіі - выход с сохранением или без. 

Меню Ргілі позволяет выполнить ряд стандартных действий 
по управлению принтером во время печати документа, включая 
запуск отчета на печать или запись отчета в текстовой файл РО$. 

После того как отчет сформирован, необходимо установить 
формат печатаемой страницы. Для этого служит позиция Раде 
сіітепзіопз. После ее выбора появляется меню с опциями: 
установка размера страницы (1.епдіН о( раде), установка сдвига 
печати слева (ОН$еі (гот ІеЙ), установка интервала между 
строками (Зрасіпд о( Ііпе$) со значениями 5ШОІ.Е - одна 
строка, РООВЬЕ - две строки, ТКІРІ.Е - три строки). 

Нередко требуется напечатать не весь документ, а только 
его часть (или повторить печать нескольких страниц). Для этого 
используется позиция Оиіриі орііоп$. В меню этой позиции 
имеются опции: начать печать со страницы с N (Ы - порядковый 
номер страницы) (Ведіп оп раде), окончить печать на странице 
с номером N (ЕпсІ аЙег раде), установить начальный номер на 
первой печатаемой странице (Ріг$і раде питЬег). При этом 
номер страницы будет печататься только в том случае, если 
задана функция печати номера страницы (Радело). 

Для установки этой функции нужно выбрать в меню РіеІ<1$ 
основного (горизонтального) меню разработки отчета позицию 
А66 ЯеЫз, а затем в высветившейся таблице установить курсор 
на позицию Радело колонки РКЕОЕРІИЕй и нажать клавишу Еліег. 
После этого высветится окно, в котором показан шаблон поля 
номера страницы, заданный по умолчанию (Тетріаіе), позиция 
для задания функций поля (Рісіиге (ипсііопз) и опция для 
подавления повторяющихся значений полей ($иррге$ гереаіесі 
ѵаіиез ѴЕ5/ИО). В документах номер страницы обычно окружа¬ 
ется знаками "тире". Чтобы эти знаки печатались, нужно 
поставить их в шаблоне, который будет выглядеть, например, 
так: {- 99 -}. Для фиксации изменения шаблона нужно нажать 
Епіег, а затем сохранить все значения клавишами СМ-ЕпсІ. 

Возвращаясь к меню Ргіпі, укажем, что для распечатки 
нескольких копий документа служит опция ЫитЬег о( соріе$. 
Отметим, что в качестве начального и конечного номеров 
печатаемых страниц при перепечатке надо указывать не физичес¬ 
кие номера страниц, а их порядковые номера, соответствующие 
принятой нумерации, начиная с заданного номера на первой 
физической странице. 

Позиция СопігоІ о( ргіліег позволяет направить на принтер 
команды (управляющие коды) для управления его действиями. 
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Если подача бумаги на принтере не автоматическая, то обычно 
требуется установить режим приостановки принтера после печати 
страницы для заправки новой страницы. Для этого используется 
опция М^аіі Ьеіжееп раде$. На принтерах обычно имеются 
переключатели шага печати - РІСА, ЕЫТЕ, СОЫОЕИ5ЕО. 

Опция Техі ріісЬ позволяет установить один из них дистанци¬ 
онно, что удобно, если принтер стоит далеко от ПК. В этой 
опции имеется также значение ОЕРАІЛТ, служащее для использо¬ 
вания шага печати, установленного на принтере. Можно также 
дистанционно установить качественную печать (опция Оиаіііу 
ргіпі - значения ѴЕ$, ИО и ОЕРАІЛТ), направить на принтер 
стартовые и финишные управляющие коды - опции $іагііпд 
сопітоі сосіез и Епсііпд сопігоі сосіез, установить режим подачи 
бумаги - опция Асіѵапсе раде изіпд со значениями: І.ІИЕ РЕЕй 
(построчно), РОКМ РЕЕР (постранично) и установить режим 
перехода к новой странице - опция Иеж раде со значениями: 
ВЕРОКЕ (переход к новой странице до печати отчета), ВОТН 
(переход к новой странице до и после печати отчета), ИОИЕ 
(без перехода к новой странице), АРТЕК (переход к новой 
странице после печати отчета). 

Позиция Оезііпаііоп позволяет вывести отчет на принтер или 
в текстовой файл Р05 в зависимости от установки опций >Ѵгііе 
іо ргіпіег/0О$ Рііе (переключение выполняется клавишей Епіег). 
Если отчет нужно направить в файл 005, тогда требуется 
присвоить ему имя в опции Ыате оі 005 Рііе. Опция Ргіпіег 
тосіеі служит для установки типа принтера: СЕИЕКІС или А5СІІ 
ТЕХТ. Э та опция используется и в том случае, если отчет 
направляется в файл 005, так как в этот файл включаются 
управляющие коды того принтера, на котором впоследствии 
предполагается печатать файл 005. Значение ОЕЫЕКІС использу¬ 
ется при создании файла, включающего наиболее общие 
управляющие коды принтера, а А5СІІ ТЕХТ - для создания 
текстовых файлов. Опция ЕсНо іо зсгееп позволяет высвечивать 
печатаемый отчет на экране. 

Иногда требуется перевести страницу на принтере не 
непосредственно перед печатью отчета, а заранее. При выборе 
позиции Еіесі раде пож страница переводится немедленно. 

Все сделанные установки для принтера целесообразно 
записать в специальный файл установок печати выбором позиции 
5аѵе $еіііпд$ іо ргіпі Іогт. После этого высвечивается окно Епіег 
пате о( ргіпі Іііе с текущим маршрутом по директориям и 
именем отчета, если до этого отчет уже был сохранен на диске 
с помощью позиции 5аѵе іЬІ5 герогі меню Ьауоиі. ? т о имя 
можно принять для файла установок или дать свое имя. 
Сохраненный файл установок печати отчета будет автоматически 
вызываться при печати отчета. Кроме печати данного отчета, этот 
файл можно использовать и для печати других отчетов. Для 
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этого его нужно выбрать из списка файлов этого типа, высвечи¬ 
ваемых после выбора позиции ІІ$е ргіпі Іогт. 

Заметим, что для печати кириллицей перед записью 
параметров печати нужно назначить тот тип принтера, который 
был задан при установке пакета сіВАЗЕ IV. Обычно к этому 
принтеру подключается драйвер, обеспечивающий печать 
кириллицы. Это назначение выполняется клавишами Епіег или 
Пробел после выбора позиции Ргіпіег тосіеі подменю (позиции) 
Оезііпаііоп меню Ргіпі Перед печатью отчет можно сначала 
вывести на экран с целью контроля правильности его формиро¬ 
вания. Для этого служит позиция Ѵіе^ героіі оп зсгееп. Собст¬ 
венно запуск отчета на печать выполняется выбором позиции 
Ведіп ргіпііпд. 

Покажем теперь, как создать программный файл отчета с 
именем МВ1, генерирующий ведомость расхода горючего 
водителями за октябрь 1989 года, представленную ниже. 

Ведомость содержит планируемый и фактический расход 
горючего каждым водителем за октябрь, перерасход или 
экономию горючего водителем, а также общий перерасход или 
экономию горючего на автопредприятии за этот месяц. В конце 
страницы печатается номер ведомости. 

Чтобы получить такую ведомость, нужно отобрать данные по 
выполненным водителями в октябре перевозкам. Для этого 
предварительно нужно составить запрос на связку файлов МІШ1, 
МЕШ2, МВйЗ, МВР4 по общим поля.» (МВ01-МВ02-МВРЗ по 
полю N.. 2, МЕЮ2-МЕШ4 по полю МАК) и выполнение отбора 
данных по перевозкам, отмеченных октябрём. 


РАСХОД 

горючего за октябрь 1989 г. 


Пункты перевозки груза 

Расстояние 

км 

Расход горючего, л 

Откуда 

Куда 

планируемый 

фактич. 

Водитель: Ермишкин Ю.И. Автомобиль: ЗИЛ-131 78-99 НМС 

Москва 

Болшево 

Ярославль 

Тула 

300 

200 

51.00 

34.00 

50.00 

33.00 

Перерасход (-), экономия (+): 2.00 

85.00 

83.00 

Водитель: Садчиков А.В. Автомобиль: ЗИЛ-131 99-99 МИД ! 

Москва 

Москва 

Г орький 

ПуД. 

400 

бв.ро 

69.00 

Перерасход (-), экономия (+): -2.20 

-с* 

ос 

о 

о 

О 

Итого расход топлива: 160.00 Перерасход (-), экономия ( + ): -0.20 | 


Ведомость N 35 
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Этот запрос формируется в окне Оиегіе$ УЦ подобно 
запросу на связку файлов МС115, описанному в разделе создания 
запросов, а в качестве критерия поиска в файле МЕЮЗ в поле 
V (дата выезда) нужно ввести условие 

> = {01.10.89}, < ={31.10.89} 

согласно которому будут отбираться записи по перевозкам, 
выполненным в октябре и дадим этому запросу имя МСН6. 
Напомним, что в формируемый шаблон вывода для связки 
файлов надо включать все поля, которые будут использоваться 
в отчете. 

Как уже упоминалось в разделе формирования запросов, 
связку файлов можно выполнить с помощью меню или вручную 
с клавиатуры. В качестве упражнения создайте вручную с 
клавиатуры запрос аналогичный МС116, помещая в графы общих 
полей какие-либо имена, например, для поля имя И, а для 

поля МАК - ИМЯ Ц, и запишите его под именем М017. Для 
вывода на печать данных о всех перевозках нужно в запросе 
М017 ( или М016) удалить критерий отбора. Запишите этот 
запрос под именем М018. 

Перед созданием отчета следует активизировать один из 
запросов МСН6, МСМ7 или МСМ8 - выбрать его в окне Оиетіез 
панели УЦ. Создание отчета начинается выбором позиции 
<стеаіе> в окне Кероііз УЦ. После этого высвечиваются 
стандартные полосы, из которых составляется отчет. Сверху 
помещается полоса заголовка страницы (Раде Неасіег ВапсІ), 
ниже полоса введения в отчет (Кероті Іпіто ВапсІ). Это означает, 
что заголовок страницы будет печататься и во введении в отчет. 
Чтобы избежать этого, выберите значение N0 позиции Раде 
Ьеасііпд іп герогі іпіто меню ВапеІз. После этого полоса Кероті 
Іпіто ВапсІ переместится вверх. 

Поскольку в ведомости надо вывести группы данных по 
выполненным каждым водителем перевозкам, то установите 
группирование записей по полю РАМ (фамилия). В этом случае 
все отобранные по каждому водителю записи из связанных 
файлов БД будут подобраны в отдельные группы, которые и 
составят содержание ведомости. 

Для группирования записей по полю РАМ выберите позицию 
АсісІ а дгоир ЬапсІ, а затем позицию РіеІсІ ѵаіие меню Вапск и 
в высветившемся окне из списка полей - поле РАМ. После этого 
на экране появятся еще две полосы Стоир 1 Іпіто ВапсІ и Сгоир 
1 Зиттату ВапсІ. 

Разработку частей отчета целесообразно начать с ввода 
текста введения в отчет (полоса Керогі Іпіто ВапсІ). В нашем 
случае введением в отчет будет заголовок ведомости. Для этого 
сначала введите две пустые строки в эту полосу с помощью 
позиции АсісІ Ііпе меню >УогсІ$ или нажав два раза клавишу 
Епіег, а затем текст заголовка. 
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— Керогі Іпіго Вапсі - 

РАСХОД 

горючего за октябрь 1989 г. 

— Раде Неасіег Вапсі- 

В полосу заголовка страницы (Раде Неасіег Вапсі) введите 
заголовок страницы, который будет печататься вверху каждой 
страницы отчета. Линии вычерчиваются с помощью позиции Ыпе 
меню І»ауоиі подобно тому, как это описано в разд. 2.6. 

Следует отметить, что для соединения при выводе ведо¬ 
мости вертикальных линий заголовка с вертикальной разграфкой 
тела отчета, нужно в заголовке для этих вертикальных линий 
сделать отводы вниз, как показано ниже. Это же относится к 
соединению вертикальных линий разграфки тела отчета с 
подножием страницы и другими частями отчета, где такие 
отводы надо делать вверх или вниз. 


— Раде Неасіег Вапсі 


Пункты перевозки груза 

Расстояние 

км 

Расход горючего, л 

Откуда 

Куда 

планируемый 

фактич. 


— бгоир 1 Іпѣго Вапсі 


Теперь приступим к формированию полосы заголовка группы 
Сгоир 1 Іпіго Вапсі. Введите в нее поля РАМ, ИАМ, ОТС, МАК, 
2, расположив их следующим образом: 

— бгоир 1 Іпіго Вапсі - 

Водитель: ХХХХХХХХХХХХХХ Х.Х. Автомобиль: ХХХХХХХХХ ХХХХХХХХ І 

- т --- Г - т -Т-1 

— йеіаі 1 Вапсі - 

РАН ИАМ ОТС МАР Н_1 

Ввод полей осуществляется выбором позиции АсЫ ІіеІсІ меню 
РіеІсІ$ или более коротким способом - клавишей Р5. Предвари¬ 
тельно нужно установить курсор на ту позицию в полосе, где 
должно размещаться поле. 

Поясним более подробно процесс ввода поля РАМ. Сначала 
целесообразно ввести текстовую часть перед этим полем - 
"Водитель:". Затем установите курсор после этого слова и 
нажмите клавишу Р5. Высветится таблица с четырьмя колонками 
МОІб (перечень имен полей активной выборки, в данном 
случае с именем МОІб), САЮШАТЕР (перечень имен вычисля¬ 
емых полей), РКЕОЕРІЫЕй (системные поля), 51ШМАКѴ 
(суммируемые поля). Из списка полей в колонке МОІб 
выберите поле РАМ. После этого на экране появится окно для 
установки параметров поля с позициями Тетріаіе (шаблон поля), 
Рісіиге Іипсііопз (функции поля) и 5иррге$$ гереаіесі ѵаіиез 
(подавить поворяющиеся значения поля). Примем установленные 


4 - 6340 
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по умолчанию значения этих позиций для поля РАМ, для чего 
надо нажать клавиши СігІ-ЕпсІ. 

После поля РАМ введите последовательно поля ЫАМ (имя), 
ОТС (отчество), МАК (марка) и N _ 2 (номерной знак). 
Заметим, что при вводе полей ЫАМ и ОТС их шаблоны нужно 
представить в виде "X.", чтобы выводить только инициалы 
водителя с точками. Изменение шаблона поля выполняется в 
следующей последовательности. Сначала установите курсор на 
поле, затем нажмите клавишу Р5 для вызова окна параметров 
этого поля, затем выберите в этом окне позицию Тетріаіе и 
нажмите клавишу Епіег, после чего курсор установится в 
шаблоне и его можно изменять (редактировать) как обычное 
поле посредством ввода или удаления требуемых знаков с 
клавиатуры. 

В тело отчета (полоса ОеіаіІ ВапсІ) нужно ввести поля, 
включающие данные о перевозках, выполненных водителем. Это 
поля 0__Р (исходный пункт), К_Р (конечный пункт), КА$ 
(расстояние), КСК (расход горючего фактический) и вычисляе¬ 
мое поле КОР, определяющее планируемый расход горючего. 
Ввод всех полей кроме КОР осуществляется аналогично полям 
в полосе Огоир 1 Іпіго ВапсІ. Поясним более подробно процесс 
создания вычисляемого поля. Значение поля КОР вычисляется по 
формуле 

КОР = К$Х*КА$/100 

где К$Х - расход горючего в литрах на 100 км, определенный 
в технических характеристиках автомобиля, а КА$ - пройденное 
автомобилем расстояние. 

Для создания вычисляемого поля КОР сначала переместите 
курсор в позицию, где нужно разместить это поле и нажмите 
клавишу Р5 (напомним, что действие этой клавиши эквивалентно 
выбору позиции АсІсІ ІіеІсІ меню РіеІсІ$), после чего высветится 
уже известная таблица с четырьмя колонками: МОІб (перечень 
имен полей активной выборки), САЮІЛАТЕО (перечень имен 
вычисляемых полей), РКЕРЕРІЫЕО (системные поля), 51ІММАКѴ 
(суммируемые поля). Для создания вычисляемого поля устано¬ 
вите курсор на позицию <сгеа!е> колонки САЮШ-АТЕР и 
нажмите клавишу Епіег, после чего высветится окно для 
установки параметров вычисляемого поля. Введите имя вычисляе¬ 
мого поля КОР и его описание, например, "Планируемый расход 
горючего", выбрав позиции Иате и Оехсгірііоп. В позицию 
Ехргеззіоп введите арифметическое выражение КА$*К$Х/100, по 
которому будет вычисляться значение поля КОР. По умолчанию 
в позиции Тетріаіе высвечивается шаблон поля, равный длине 
поля, определенной при создании структуры файла БД. Чтобы не 
выводить лишние позиции, сократите этот шаблон (клавишами 
РеІ или Васкзрасе), оставив четыре знака до точки и два после 
(9999.99). После установки всех параметров вычисляемого поля 


98 



нажмите клавиши СігІ-ЕпсІ. Вычисляемое поле ВОР создано и 
введено в тело отчета. После этого тело отчета выглядит так: 

— йеіаі 1 ВапсІ- 

| ХХХХХХХХХХХХ | ХХХХХХХХХХХХХХ | 9999 | 9999.99 | 9999.99 | 

— Ѳгоир 1 Зиттагу ВапсІ--— 

0_Р К_0 РАЗ Р6Р В6В 

Перейдем теперь к полосе подножия группы (Сгоир 1 
Зилптагу ВапсІ), в которую нужно ввести три вычисляемых поля 
для расчета общего планируемого (5ВР) и фактического ($ВВ) 
расхода горючего каждым водителем за октябрь, а также поле 
для расчета перерасхода или экономии горючего (5КР-5КК) ЭТИМ 
водителем. 

Сначала создадим поле 5ВВ. Для этого установите курсор на 
нужную позицию в полосу Сгоир 1 Зиттагу ВапсІ, нажмите 
клавишу Р5, после чего высветится уже известная таблица и 
теперь для создания суммируемого поля в колонке 51ІММАВѴ 
выберите позицию Зит. После этого высветится окно для 
установки параметров суммируемого поля. Введите имя вычис¬ 
ляемого поля - и его описание - "Общий фактический 

расход", выбрав соответственно позиции ЫАМЕ и Оезсгірііоп. 
Далее надо указать поле, по которому будет выполняться 
суммирование и определяться общий фактический расход 
горючего. Это поле ВСВ выборки МОІб. Для этого установите 
курсор на позицию РіеІсІ іо зиттагіге оп, затем из высветивше¬ 
гося окна с именами полей активной выборки МСИ6 выберите 
поле ВСВ. Затем выберите также позицию Ве$еі еѵегу, после 
чего высветится окно с позициями < ВЕРОВТ>, <РАСЕ>, РАМ. 
Первые две позиции позволяют выводить в поле $ВВ сумму 
значений поля кок соответственно в конце отчета или страницы, 
а последняя позиция, в которой стоит поле РАМ, после измене¬ 
ния фамилии. Установите курсор на позицию РАМ и нажмите 
клавишу Епіег. Это значит, что суммирование значений поля РОК 
будет выполняться только внутри группы 1, т.е. будет суммиро¬ 
ваться горючее, израсходованное каждым водителем на перевоз¬ 
ках грузов за октябрь, и выдаваться в подножии группы 1. Чтобы 
не выводить лишние позиции измените, как и при создании 
поля ВОР шаблон поля в позиции Тетріаіе на "9999.99". Для 
сохранения выполненных установок по определению поля 
нажмите клавиши СІтІ-Епс! . Создание суммируемого поля $ВР 
выполняется аналогично суммируемому полю 5ВВ с той лишь 
разницей, что суммирование будет выполняться по вычисляемому 
полю ВОР, имя которого находится в колонке СА1.СШ.АТЕ0 
таблицы, высвечиваемой после нажатия клавиши Р5. Предвари¬ 
тельно не забудьте переместить курсор на требуемую позицию 
в полосе Сгоир 1 $иттагу ВапсІ. 

Вычисляемое поле разности $ВР-$ВВ в принципе создается 
подобно другим вычисляемым полям, например, полю ВОР. 
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Различие состоит в назначении выражения вычисляемого поля 
при выборе позиции Ехрге$$іоп. В данном случае это будет 
выражение 5ВР-5ВВ. Отметим, что до сих пор вычисляемым 
полям присваивалось уникальное имя посредством его ввода с 
клавиатуры при выборе позиции Иате окна установки парамет¬ 
ров. В принципе это можно не делать. Тогда само выражение 
будет служить его именем. Это можно продемонстрировать на 
примере поля разности $ВР-$ВВ. При заполнении окна установок 
этого поля введите в позицию Ехрге$$іоп выражение $ВР-$ВВ и 
пропустите позицию Иате (в позиции Оезсгірііоп можно ввести 
описание этого выражения), сохранив заданные установки 
клавишами СІгІ-ЕпсІ. Предварительно не забудьте установить 
курсор на позицию, где будет размещаться это поле. После 
окончания формирования полей группы 1 можно обвести их 
рамкой, как показано ниже. 


Ѳгоир 1 Зитшагу Вапгі - 

.1 _ 1 . 




999.99 

999.99 


Перерасход (-), экономия (+): 999.99 

Раде Рооѣег Вапгі - 


5РР-5РР 


ЗРР 


В подножии страницы (полоса Раде Роо+ег ВапсІ) можно 
поместить номер печатаемой ведомости, как показано ниже. 

— Раде Рооіег ВапсІ - 

Ведомость N 35 

— Рерогі Зшшпагу ВапсІ - 

Перейдем к полосе итогов отчета (Вероіі 5иттагу ВапсІ). 
В конце отчета нужно подсчитать, сколько всего было истрачено 
горючего на перевозках грузов автопредприятием за октябрь 
1989 г., а также перерасход (экономию) горючего. Для 

вычисления этих показателей создайте поля 5АР (общий 
планируемый расход горючего), $АВ (общий фактический расход 
горючего), а также поле разности полей $АР и 5АВ и размести¬ 
те их в отчете так: 


— Рерогі Зипшіагу ВапсІ - 

I Итого расход топлива:999.99 Перерасход (-), экономия (+): 999.99 


ЗАР 


ЗАР-ЗАР 


Поля 5АР и 5АВ создаются аналогично полям 5ВР и 5ВВ с 
той разницей, что в позиции Везеі еѵегу нужно выбрать опцию 
<ВЕРОВТ>. Это значит, что запланированное и фактически 
израсходованное горючее всеми водителями, находящееся в 
полях ВОР и ВОВ, будет суммироваться по перевозкам, сделан- 
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ным в октябре и выдаваться в конце отчета. Кроме того, будет 
вычисляться общий перерасход или экономия горючего. Перед 
созданием полей не забудьте установить курсор на нужную 
позицию в данной полосе отчета. 

При создании поля $АР нужно учесть, что оно необходимо 
только для вычисления разности $АР-$АК, поэтому его не надо 
выводить. Поскольку это поле не будет выводиться, то при его 
создании курсор может стоять в любом место полосы. При 
создании поля $АР, как обычно, выберите позицию Асісі Ііеісі 
меню РіеІсІ5 или нажмите клавишу Р5 и затем в высветившемся 
окне в колонке 51ІММАРУ выберите позицию $шп, после чего 
в высветившемся окне установок параметров этого поля в 
позиции Ыате назначьте ему имя 5АР (можно также в 
позиции Оезсгірііоп . ввести описание этого поля), а в позиции 
РіеІсІ іо зиттагііе оп - введите поле ВОР, значения которого 
будут суммироваться и засылаться в поле 5АР. Для того чтобы 
скрыть это поле, нужно в позиции Нісісіеп установить значение 
Ѵе$. После назначения всех параметров полю $АР не забудьте 
их сохранить клавишами СігІ-Епгі. 

Поле разности 5АР-5АК создается как и любое вычисляемое 
поле, например, аналогично полю ВОР или полю разности 
5ВР-5ВВ, разумеется, после предварительной установки курсора 
на ту позицию в полосе итогов, в которой оно должно разме¬ 
щаться. Для этого поля, как и для поля 5ВР-5ВВ, можно не 
назначать имени, в качестве которого по умолчанию будет 
служить само выражение. 

Формирование структуры отчета закончено. Выбрав позицию 
Ѵіе^ герогі оп $сгееп меню Ргіпі, можно просмотреть отчет на 
экране. Если ошибок в созданном документе нет, то выберите 
позицию $аѵе СЬапдез апсі ехіі меню Ехіі, введите имя файла 
отчета МВ1 в высветившемся окне $аѵе а$ после имени диска и 
маршрута по директориям, например, 0:\0ВА$Е1 Ѵ\РВІМЕВ\МВ1, 
и нажатием Епіег сохраните программный файл отчета. 

Запуск отчета на печать можно выполнить, не выходя из 
меню разработки отчета с помощью позиции Ведіп ргіпііпд меню 
Ргіпі или из УЦ. В последнем случае нужно перед печатью 
отчета активизировать файл БД или запрос, по которому будут 
отбираться данные в отчет, затем установить курсор на имя 
отчета и нажать клавишу Епіег. Высветится горизонтальное меню 
с позициями Ргіпі герогі и МосШу Іауоиі и Різріау сіаіа. Выбор 
первой позиции высвечивает такое же меню, как и меню Ргіпі 
в форме разработки отчета. Позиция МосШу Іауоиі высвечивает 
экран разработки отчета, а позиция Різріау сіаіа выводит на экран 
в стандартной форме Вгожзе или Есііі данные из связанного с 
отчетом файла БД или выборки. 

Заметим, что отчет печатается кириллицей в том случае, 
если загружен соответствующий драйвер. Как уже упоминалось, 
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в меню Ргіпі предусмотрен вывод на несколько типов принтеров: 
СЕИЕКІС, Ахсіі іехі, Ерхоп РХ-80. 

Драйвер с кириллицей обычно подключается к тому типу 
принтера, который задается при установке пакета сІВАЗЕ IV. 
Поэтому, если кириллица не печатается, то надо в позиции 
Ргіпіег тосіеі после выбора подменю (позиции) Оехііпаііоп меню 
Ргіпі установить клавишами Епіег или Пробел тот тип принтера, 
который был назначен при установке пакета, например, Ахсіі іехі. 
В этом же меню в позиции ЕсНо іо хсгееп можно установить 
параллельный вывод отчета на принтер и экран. Полезной также 
является позиция Ыеж раде подменю СопігоІ оі ргіпіег меню 
Ргіпі, с помощью которой можно установить, также клавишами 
Епіег или Пробел, перевод страницы перед печатью отчета 
(ВЕРОНЕ), после печати отчета (АРТЕК), до и после печати 
отчета (ВОТН) или вообще не переводить (ЫОЫЕ). В учебном 
примере установлено значение ЫОИЕ. В этом же подменю с 
помощью задания значения ѴЕ$ в позиции >Уаіі Ьеіжееп раде 
можно установить ожидание в работе принтера для заправки 
нового листа. 

В подменю Раде сіітепхіопх меню Ргіпі, выбрав позицию 
1.епдіЬ оі раде, можно задать количество строк на странице. 
Поскольку в учебном примере введено лишь несколько перево¬ 
зок, которые не заполняют даже одну страницу, то число строк 
на печатаемой странице принято равным 33. 

После выполненных назначений нажмите клавишу Ехс и затем 
можно запустить отчет на печать, выбрав позицию Ведіп ргіпііпд 
меню Ргіпі. Как упоминалось выше, все установки печати можно 
сохранить в специальном файле, выбрав позицию $аѵе хеіііпдх 
іо ргіпі (огт. После этого высвечивается окно $аѵе ах, в которое 
нужно ввести имя файла установок. В качестве этого имени 
можно взять имя отчета МК1. Следует отметить, что перед 
запуском отчета на печать можно временно изменить для 
текущего сеанса печати все назначенные при создании отчета 
установки печати посредством выбора соответствующих позиций, 
но не сохраняя их в файле установок печати. Сохранение же 
изменений в файле установок означает замену старых значений 
на новые. 


2.8. РАЗРАБОТКА МАРОК 

Марки представляют собой небольшие формы, которые 
можно печатать по нескольку штук на листе. Они используются 
для печати почтовых открыток, товарных ярлыков и т.д. Если 
ширина марки кратна ширине листа, то они печатаются слева 
направо сверху вниз по листу бумаги. Если ширина марки равна 
ширине бумаги или меньше, но не кратна ей, марки будут 
печататься по вертикали. В каждой марке размещаются данные 
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одной записи файла БД. Максимальный размер марки - 255 
строк и 255 колонок. Экранная область разработки форм марок 
аналогична области разработки отчетов в режиме размещения 
полей. Особенностью вывода на печать значений полей в марках 
по сравнению с отчетами является автоматическое удаление в 
них ведущих и конечных пробелов. 

Меню разработки марок включает в основном те же 
компоненты, что и меню отчета. Отличие определяется специфи¬ 
кой формы марки. Ее структура задается меню Оітеп$іоп$ 
вместо меню Вапсіз для отчета. Все остальные меню практически 
полностью совпадают с меню разработки отчета. 

Меню Оітепзіопз позволяет выбрать стандартные размеры 
марок или установить свои. Позиция РгесІегіпесІ $ііе предостав¬ 
ляет на выбор несколько стандартных размеров (по высоте и 
ширине) марок (в дюймах). Для тех размеров, которые дают 
возможность размещать несколько марок по ширине листа, 
приводится их максимальное число. Это число дается в соответ¬ 
ствии с шагом печати символов шрифтом РІСЛ (10 символов на 
дюйм). 

Для установки собственных размеров используются позиции 
>Л^ісЖі о і ІаЬеІ (ширина марки - числом символов) и НеідМ о( 
ІаЬеІ (высота марки - числом строк). В форме марки с 
помощью позиции Іпсіепіаііоп можно установить отступ абзаца 
при вводе текста. Расположение марок на бумаге устанавливается 
позициями Ыпе$ Ьеілѵееп ІаЬеІ; (число пустых строк между 
рядами марок - до 16 линий) и $расе5 ЬеЬѵееп ІаЬеІ соІитп$ 
(число пропускаемых позиций между марками в ряду - до 120 
позиций). Количество марок в ряду определяется автоматически, 
исходя из заданных размеров, если не установлено их число с 
помощью позиции Соіитпз оі ІаЬеІ$ (до 15 марок в ряду). 

Покажем действия по разработке марки на нашем примере. 
Предположим, что в МЕШ1 помимо водителей введены данные 
на служащих предприятия. Требуется распечатать этикетки, 
приклеиваемые на рабочие шкафы служащих. Пример такой 
этикетки показан ниже. 


ШКАФ N_ 

Ответственный: Александров А.С. 


Перед созданием марки откройте файл МІШ1, затем устано¬ 
вите курсор на позицию <сгеаіе> окна І.аЬеІ$ и нажмите Епіег. 
Высветится экран создания (модификации) марок. Если Вы 
забыли открыть файл МВйІ, содержащий фамилии, имена и 
отчества, то выберите позицию ІІ$е сІіНегепі сІаіаЬазез Іііе ог ѵіеж 
меню Ьауоиі, что позволит открыть его уже после выхода на 
экран разработки марки. 
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Затем надо определить размеры марки. Ширина марки 
устанавливается в опции \ѴісМі о( ІаЬеІ меню Оітеп$іоп* и, 
допустим, равняется 39, высота - 5 (позиция НеідМ о< ІаЬеІ 
меню Оітепзіоп*), количество пустых строк между марками - 1 
(|_іпе* ЬеІ^ееп ІаЬеІ*), количество пробелов между колонками 
марок - 2 ($расе* Ьеіжееп ІаЬеІ* соіитп*), число колонок - 2 
(Соіитп* о} ІаЬеІ*). При нажатии клавиши Е*с окно марки на 
экране изменяет свои размеры в соответствии с параметрами, 
установленными в меню Оітеп*іоп$. 

Теперь установите курсор в нужную позицию и введите 
текст "ШКАФ N_" и "Ответственный:". 

Следует отметить, что в неадаптированной версии СІВА5Е IV 
при разработке экранных форм, отчетов, марок и прикладных 
программ не вводятся русские прописные буквы "К" и "Н", 
которые нужно заменять соответствующими латинскими буквами. 
Затем нужно ввести в марку поля, которые будут выводиться, - 
РАМ, ИАМ и ОТС. Для этого используется позиция АсІсІ ІіеІсІ 
меню РіеІсІ*, а из высветившегося списка полей файла БД - 
выбирается требуемое поле. Затем высветится окно с установка¬ 
ми параметров поля, которые при вводе поля РАМ изменять не 
будем и сохраним эти установки клавишами СМ-Епсі, после чего 
поле будет размещено в текущей позиции курсора. Не забудьте 
перед размещением каждого поля устанавливать курсор на 
требуемую позицию. 

При вводе поля ЫАМ нужно изменить шаблон, чтобы 
высвечивалась только первая буква и точка после нее. Для этого 
выберите позицию Тетріаіе в окне с параметрами поля и 
измените шаблон поля, оставив только один символ X с точкой 
("X."). Нажмите Епіег для фиксации изменения и затем СІтІ-ЕпсІ 
для сохранения параметров поля. Аналогично введите в марку 
поле ОТС. В итоге шаблоны полей РАМ, ИАМ и ОТС будут 
выглядеть следующим образом: "ХХХХХХХХХХХХХХХ Х.Х.". 

Для обведения этикетки рамкой переместите курсор в левый 
угол марки, нажмите клавишу АН и не, отпуская ее, нажмите 
последовательно на правой цифровой клавиатуре цифры 2,1,8 
(код А5СІІ символа левого верхнего уголка). После этого 
отпустите клавишу АН, и на экране высветится левый верхний 
уголок. Обозначим нажатие этих клавиш как АІі>218. В правом 
верхнем, правом нижнем и левом нижнем углах марки нажмите 
соответственно клавиши АІІ-191, АІ1-217 и АІ1-192. Теперь остается 
только соединить уголки горизонтальными и вертикальными 
линиями, нажимая нужное число раз соответственно клавиши 
АІі-196 и АІ1-179. Этикетка на шкаф готова. Для проверки 
просмотрите созданную форму этикеток на экране, выбрав 
позицию Ѵіеж ІаЬеІ* оп *сгееп меню Ргіпі. 

Наконец, нужно установить опции печати. При условии, что 
этикетки будут распечатываться на стандартном листе в две 
колонки, опции будут следующие: количество строк на странице 
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(позиция І.епдіЬ о! раде подменю Раде Оітепзіопз) - 60, отступ 
слева (позиция ОНзеі (гот Іе(( этого же подменю) - 2. Для 
установки ожидания перед печатью очередного листа установите 
опцию "Ждать между страницами" (позиция \Ѵаіі Ьеіѵѵееп 
радез - ѴЕ$ подменю СопігоІ о( Ргіпіег), а также опцию "Вывод 
на принтер" (позиция >Угііе іо ргіпіег подменю Оехііпаііоп) 

Установки печати целесообразно сохранить в специальном 
файле, который будет автоматически вызываться при печати 
марки. Запись установок в этот файл осуществляется выбором 
позиции $аѵе $еіііпд$ іо ргіпі (огт. После этого высвечивается 
окно Епіег пате о( ргіпі (ііе с текущим маршрутом по директо¬ 
риям. Введите имя, например, МІІ$Т, которое нужно зафиксиро¬ 
вать клавишей Епіег. 

Для сохранения программного файла марки на диске 
выберите позицию $аѵе іНіх ІаЬеІ сіезідп меню Ьауоиі и введите 
имя разработанной марки - МИ в окно 5аѵе а$ после текущего 
диска и директория. Далее нажмите клавишу Епіег. Запуск марки 
на печать без выхода из экранной формы можно выполнить, 
выбрав позицию Ведіп ргіпііпд меню Ргіпі. 

Выход в УЦ из экрана создания (модификации) марки 
осуществляется выбором любой из позиций меню Ехіі, поскольку 
ее файл уже записан на диск. Для вывода марки на печать из 
УЦ нужно выбрать ее имя в окне І.аЬеІ5, затем в высветившемся 
меню выбрать позицию Ргіпі ІаЬеІ, после чего откроется такое 
же меню, как и при выборе меню Ргіпі в случае запуска марки 
из экранной формы ее разработки, в котором можно выбрать 
опцию для высвечивания марки на экране (Ѵіеіѵ ІаЬеІз оп 
$сгееп) или начать печатать (Ведіп ргіпііпд). Перед этим можно 
изменить ранее сделанные установки печати (позиции Оиіриі 
орііопз, Раде 4ітеп$іоп$ и др.). 


2.9. ГЕНЕРАТОР ПРИКЛАДНЫХ ПРОГРАММ 

Генератор прикладных программ позволяет создавать 
программные файлы (программы) на языке сіВАЗЕ IV пользова¬ 
телям, не знающим команд этого языка. Эти программы дают 
возможность работать с ранее созданными файлами БД, 
экранными формами ввода и вывода информации, запросами на 
выборку и обновление данных в файлах БД, отчетами и 
марками. Кроме того, в программах генерируются меню 
выполнения операций с указанными выше объектами. В приклад¬ 
ную программу можно также вводить команды языка сІВАЗЕ IV, 
включая разработанные ранее процедуры и программные 
модули. Для подготовленных пользователей и программистов 
генератор дает возможность уменьшить трудозатраты на 
разработку сложных программ посредством использования 
заранее разработанных унифицированных модулей. 
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\ Собственно генератор прикладных программ позволяет 
создавать следующие компоненты: главную процедуру програм¬ 
мы, горизонтальные и вертикальные меню и списки файлов, 
полей файлов БД/выборок, значений поля файла БД/выборки. 
Списки похожи на меню - курсор может передвигаться по 
позициям списку а после выбора позиции (клавишей Епіег) 
выполняется заданнде действие. Отличие меню от списка состоит 
в том, что каждой позиции меню можно назначить свое 
действие, а списку только одно общее действие. Ниже для 
общности под термином меню будут пониматься также и списки, 
а при упоминании файла БД под ним будет также подразуме¬ 
ваться и выборка. Кроме этих компонентов генератор позволяет 
создать особый компонент - программный модуль ВаісЬ, который 
может назначаться для выполнения при выборе позиций меню 
или списков. Можно также назначить его запуск самостоятельно, 
например, в начале выполнения прикладной программы. Этот 
модуль создается как меню вертикального типа. Каждой позиции 
меню модуля ВаісН назначается определенное действие. Текст 
позиции служит для пояснения выполняемого действия, как и в 
обычном меню. Отличие модуля ВаісН от меню состоит в том, 
что меню модуля ВаісЬ при его вызове не высвечивается на 
экране и все действия, назначенные позициям его меню, 
выполняются в пакетном режиме - как один модуль. По 
существу, модуль ВаісН предназначен для неподготовленных 
пользователей как инструмент по созданию обычных програм¬ 
мных модулей. 

Меню прикладной программы можно реализовать в виде 
сложной многоуровневой системы, включающей меню горизон¬ 
тального и вертикального типов и списки. Меню состоит из 
главного меню и прикрепленных к его позициям меню нижесле¬ 
дующих уровней. В качестве главного меню может быть меню 
горизонтального или вертикального типов. Прикладная программа 
может также начинаться выполнением модуля ВаісН. Позициям 
меню назначаются операции с файлами и другие действия. 

Перед и после вызова меню или выполнения позиций меню 
можно назначить выполнение команд сІВАЗЕ IV, например, 
команду вызова процедуры, написанной на языке сІВАЗЕ IV или 
501-. В состав программы, создаваемой генератором, входит 
главная процедура, в которой делаются установки параметров и 
опций 5ЕТ-команд, переменных и т.д. и вызываемые из главной 
процедуры программные модули и ком анды, а также меню и 
процедуры. С помощью меню, посредством выполнения 
процедур или команд можно вызывать заранее разработанные 
запросы на обработку файлов БД, экранные формы ввода и 
вывода информации, отчеты, марки, а также различные 
процедуры и функции. Использование этих возможностей УЦ и 
генератора прикладных программ в сочетании с программирова¬ 
нием дополнительных объектов на языке сІВАЗЕ IV и 501- 
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позволяет создавать прикладные программы любой степени 
сложности. 

Разработка прикладной программы выполняется с помощью 
меню генератора, включающего следующие позиции: Ое$ідпе, 
Арріісаііоп, Оепегаіе, Рге$еі, Ехіі При разработке меню, списка 
или модуля ВаісН вместо позиции Арріісаііоп, служащей для 
разработки главной процедуры, высвечиваются соответственно 
позиции Мели, Ы$і или ВаІсН и добавляется общая для всех 
позиция Нет. Собственно разработка компонентов прикладной 
программы выполняется с помощью позиций (меню) Ое$ідпе, 
Арріісаііоп, Мели, І.І5І, ВаісН и Нет. Остальные позиции выполня¬ 
ют служебные функции: Сенегале - генерацию прикладной 
программы, Ргезе! - предварительную установку параметров 
сІВАЗЕ IV, Ехіі - выход из генератора прикладных программ. 

Перед разработкой прикладной программы целесообразно 
назначить общие установки и параметры сІВАЗЕ IV, которые 
распространяются на всю прикладную программу. Особенно это 
полезно, если предполагается разрабатывать серию прикладных 
программ, в которых используются унифицированные компонен¬ 
ты. Меню Рге$еі содержит опции, позволяющие назначить 
текущий диск и маршрут по директориям для файлов, которые 
будут обрабатываться в прикладной программе, данные об 
авторе прикладной программы, авторских правах и используемой 
версии сІВАЗЕ IV (могут высвечиваться в заставке при запуске 
прикладной программы), а также некоторые установки сІВАЗЕ IV, 
включая цвет различных областей экрана, подачу звукового 
сигнала при определенных ситуациях, ряд установок для 
обработки файлов БД и др. В дальнейшем установки, сделанные 
в меню Ргезеі, можно изменить, дополнить и конкретизировать 
при разработке компонентов прикладной программы в соответ¬ 
ствии с их функциями. 

Для назначения диска и маршрута по директориям выбира¬ 
ется опция Арріісаііоп сІгіѵе/раіЬ меню Рге$еі, после чего в 
соответствующие графы высветившегося шаблона вводится имя 
диска (Огіѵе) и маршрут по директориям (ЗеагсЬ раіЬ). Опция 
Зідп-оп сіеіаиііз служит для ввода данных в заставку прикладной 
программы. После выбора этой опции высвечивается шаблон, в 
графы которого требуется ввести данные: имя автора (АиіЬог), 
авторские права (СоругідМ поіісе) и версию используемого 
пакета сІВАЗЕ IV (сІВАЗЕ ѵегзіоп). Следует отметить, что эти 
данные будут высвечены в заставке не текущей, а только 
следующей разрабатываемой прикладной программой. Сохране¬ 
ние введенных в шаблоны значений выполняется клавишами 
СІтІ-ЕпсІ. Ниже при описании различных меню всегда будет 
подразумеваться, что после ввода данных в шаблон их нужно 
сохранить клавишами СІтІ-ЕпсІ. 

Опция Епѵігоптепі $еіііпд позволяет включить (ОН) ИЛИ 
ВЫКЛЮЧИТЬ (ОРР) клавишей Пробел установки на выполнение 
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следующих действий: подачу звукового сигнала при определен¬ 
ных ситуациях, например, после заполнения поля файла БД 
данными ($еі ВЕН), копирование содержимого поля из 
предыдущей записи в последующую ($еі САВКУ), вывод 
четырех цифр года (включая цифры столетия) в дате ($еі 
СЕИТЦКУ), автоматический переход в следующее поле записи 
после заполнения предыдущего (5еі СОИРІВМ), прерывание 
выполнения задачи клавишей Е$саре (5еі Е5САРЕ), высвечивание 
предупреждающего сообщения при удалении файла БД ($еі 
5АРЕТУ) и установку нестандартного разделителя полей файлов 
БД ($еі ЬЕЫМЕТЕКЗ іо). При включении звукового сигнала 
можно установить его частоту и длительность. 

Цвета экрана устанавливаются опцией Оізріау орііопз 
посредством выбора позиций: цвета текста и заголовков 

($іапс!агсІ - АН), цвета внутренней части рамок компонентов, 
поля и подсвеченные позиции (ЕпЬапсесІ - АН), цвет текста, а 
также не активные поля на экране в форме Вготе (ИогтаІ 
іехі), цвет сообщений в нижней части экрана, а также не 
активные меню и списки (Ме55аде$), цвет заголовков типа имен 
полей в таблице Вгоѵѵзе, а также линий в этой таблице (ТііІе$), 
цвет подсвеченных позиций меню и списков (НідНІідЬі), цвет 
внутренней части рамок меню и списков (Вохез), цвет 

информационной строки, часов, рамки сообщений об ошибках 
(Іпіогтаііоп), цвет активных полей файлов БД в таблице Вготе 
и других редактируемых полей (Ріеісіз). 

Разработка прикладной программы обычно начинается с 
создания главной процедуры. Экран разработки главной 
процедуры появляется после выбора позиции <сгеаіе> в окне 
Арріісаііоп; на панели УЦ и затем опции МосШу арріісаііоп и 
представляет собой шаблон с графами, в которые требуется 
ввести следующие данные: имя главной процедуры (Арріісаііоп 
пате), тип главного меню программы (Маіп тепи іуре), имя 
этого меню (Маіп тепи пате), файл БД, используемый в 
программе (ОаіаЬа$е/Ѵіеж), индексные файлы типа .псіх или 
.тсіх, связанные с этим файлом БД ($еі іпсіех іо), главный 
(управляющий) индекс типа .псіх или указатель множественного 
индексного файла типа .тсіх (ОКОЕК) и словесное описание 
главной процедуры (Оезсгірііоп). Управляющий индекс (указа¬ 
тель индекса) можно задать в виде его имени или порядкового 
номера из списка файлов типа .псіх или указателей файлов типа 
.тсіх. 

Выбор типа главного меню выполняется клавишей Пробел из 
трех значений (Ваг - горизонтальное, Рор~цр - вертикальное 
меню, модуль ВаісН). Имя файла БД можно ввести с клавиатуры 
или выбрать из списков файлов БД в текущем и других 
директориях дисков, высвечиваемых клавишами 5НІІІ-Р1. 

В верхней части этого списка имеется позиция <сгеаіе>, 
позволяющая создать новый файл БД, ввести в него данные и 

108 



затем вернуться в генератор прикладных программ в ту точку, 
из которой был выполнен выход на создание файла БД. Эту же 
операцию можно выполнить для всех типов файлов - индексных 
файлов, запросов, экранных форм, отчетов и марок, файлов 
меню, списков и модуля ВаісЬ. В дальнейшем, когда будет 
упоминаться ввод имени любого типа из перечисленных файлов 
или имен полей файла БД, всегда будет предполагаться возмож¬ 
ность ввода имени с клавиатуры или выбора этого имени из 
списков в директориях дисков, высвечиваемых клавишами 5НІН-Р1, 
а также возможность их немедленного создания с помощью 
позиции <сгеаіе> этого списка. 

После сохранения введенных в шаблон главной процедуры 
данных высвечивается окно, представляющее собой заставку, 
которая будет появляться при запуске созданной прикладной 
программы. Внутри окна можно записать свой текст, а также 
изменить размеры окна и переместить его на другое место 
экрана. Изменение размеров окна выполняется навигационными 
клавишами после нажатия клавиш 5НІЙ-Р7. Новый размер окна 
фиксируется клавишей Епіег. Для передвижения окна сначала 
нажимается клавиша Р7, затем окно можно передвигать навигаци¬ 
онными клавишами. Новое место окна также фиксируется 
клавишей Епіег. 

Дальнейшие действия по созданию главной процедуры 
выполняются с помощью меню Арріісаііоп. Опция Нате апсі 
сІезсгіЬе этого меню позволяет подтвердить или изменить 
введенное ранее имя и словесное описание главной процедуры, 
а опция Л$$ідп таіп тегш - подтвердить или изменить имя 
ранее введенного главного меню. Сохранение введенных 
значений выполняется клавишами СігІ-ЕпсІ. Для подтверждения 
ввода в прикладную программу заставки выбирается опция 
йізріау зідп-оп Ьаппег (ответ Ѵе$ на предложение Різріау (гате 
а* гг 5Ідп оп Ьаппег" а* ічіп Тіте). Если ответ N 0 , то при запуске 
прикладной программы сразу высвечивается главное меню. 
Опция Есііі ргодгат Неасіег соттеп*$ осуществляет ввод в 
комментарий текста сгенерированной программы данных об 
авторе прикладной программы (Арріісаііоп аиіНог), сведений о 
правах на копирование (СоругідЬі поіісе) и используемую 
версию СІВА5Е IV (сІВА$Е ѵегзіоп). После генерации программу 
с комментарием можно вывести на печать в режиме ввода 
команд с клавиатуры, используя команду Туре <имя програм- 
мы> оп ргіпіег или с помощью меню Ргіпі текстового редактора 
СІВА5Е IV. 

Опция Мосіііу арріісаііоп епѵігоптепі дает возможность 
изменить назначение текущего диска, маршрут по директориям, 
ввести имя файла БД, который будет обрабатываться в приклад¬ 
ной программе, и связанные с ним индексные файлы, а также 
изменить другие установки сІВАЗЕ IV, ранее выполненные в 
меню Ргехеі После выбора этой опции высвечивается меню, 


109 



позволяющее ввести необходимые данные. Три опции этого 
меню (йізріау орііопз, Епѵігоптепі зейіпд, $еагсЬ ра*Ь) пол¬ 
ностью совпадают с опциями меню Ргезеі. Четвертая опция 
Ѵіеж/сІаІаЬазе апсі іпсіех используется для ввода имени файла 
БД, связанного с ним индексного файла и указателя индекса в 
множественном индексном файле. После выбора этой опции в 
высветившийся шаблон в соответствующие графы вводится (если 
не введено раньше) имя файла БД (ОаіаЬазе/ѵіеж), имя одного 
или нескольких индексных файлов типа .псіх или .ѵпсіх ($еі іпсіех 
♦о), а также имя главного (управляющего) индекса (указателя 
индекса для файла типа .тсіх) или его порядковый номер 
(Огсіег). 

Опция Сепегаіе яиіск арріісаііоп меню Арріісаііоп позволяет 
создать стандартную прикладную программу с одним вертикаль¬ 
ным меню, в котором автоматически формируются позиции (на 
английском языке) для добавления, изменения, вывода на экран 
в стандартной форме Вгожзе и удаления записей файла БД. 
Генератор автоматически присваивает этой программе имя 
Оискарр. Текст позиций меню можно после генерации програм¬ 
мы заменить на русский язык при модификации программы. Для 
этой программы можно также задать поиск по индексу, выдачу 
на печать ранее сформированного отчета или марки, а также 
ввод и вывод информации в ранее разработанной экранной 
форме. После выбора этой опции нужно ввести (или изменить) 
в соответствующие графы шаблона следующие данные: имя 
файла БД, предназначенного для обработки в программе 
(РаіаЬазе (Не), имя экранной формы (Зсгееп (огтаі (Не), имя 
отчета (Керогі (огтаі (Не), имя марки (1.аЬеІ (огтаі (Не), имя 
одного или нескольких индексных файлов (5еі ЖОЕХ іо), имя 
или число, определяющее порядковый номер главного индекса 
(указателя индекса) в списке индексных файлов типа .псіх или 
файла типа .тсіх. (Огсіег), имя автора прикладной программы, 
которое вводится в качестве комментария в программу и 
документацию, создаваемую генератором прикладных программ 
(Арріісаііоп аиіЬог), заголовок меню, создаваемого генератором 
(Арріісаііоп тепи Неасііпд). 

Сохранение всей введенной информации выполняется 
клавишами СігІ-ЕпсІ, после чего высвечивается предложение на 
генерацию программы (ѴЕ5 - программа генерируется, ЫО - 
нет). Если программа не создана, то ее можно сгенерировать 
впоследствии, выбрав позицию Зеіесі іетріаіе меню Сепегаіе и 
затем введя Оиіскарр.деп - имя файла шаблона этой прикладной 
программы, используемого при генерации. 

Для сохранения разработанной главной процедуры нужно 
выбрать позицию 5аѵе сиггепі арріісаііоп 4е(іпіііоп меню 
Арріісаііоп, которая записывает на диск файл разработки главной 
процедуры с расширением .арр. В этом меню еще имеется 
позиция Сіеаг ѵ/огк $иг(асе, которая используется обычно при 
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разработке других компонентов прикладной программы - меню, 
списков и модулей ВаісЬ - и позволяет удалить с рабочей 
поверхности экрана все компоненты, кроме главной процедуры 
(на экране главная процедура высвечивается в виде рамки 
заставки). 

Следующим этапом разработки прикладной программы 
обычно является создание меню. Для этого используется меню 
Ое$ідпе, позволяющее создавать горизонтальные, вертикальные 
меню, модуль ВаісН и списки. Эти компоненты записываются на 
диск в виде файлов с различными расширениями, идентифици¬ 
рующими их тип: горизонтальные (.Ьаг) и вертикальные (.рор) 
меню, модуль ВаісН (.ЬсН), списки файлов (ЛіІ), списки полей 
файлов БД (.$1г), списки значений полей файлов БД (.ѵаі). 
Создание определенного типа меню, списка и модуля ВаТсЬ 
осуществляется выбором опций меню йезідпе: горизонтальное 
меню (НогігопіаІ Ьаг тепи), вертикальное меню (Рор-ир тепи), 
список файлов (РіІе5 Іі$і), список полей файла БД (Зігисіиге 
Іі$і), список значений поля файла БД (ѴаІие$ Іі$1), модуль ВаісН 
(ВаісН ргоседе). 

После выбора опции создания горизонтального меню 
высвечивается список, из которого можно выбрать существующие 
в текущем директории файлы этого типа меню. Для создания 
нового горизонтального меню требуется выбрать позицию 
<сгеаіе> в этом списке. Затем высвечивается окно, в графы 
которого требуется ввести: имя меню (Иате), словесное 
описание меню (Оезсгірііоп), текст сообщения, который будет 
высвечиваться внизу экрана при выборе данного меню в ходе 
выполнения прикладной программы (Ме$$аде Ііпе рготрі). 
Введенные данные следует сохранить клавишами СІгІ-ЕпсІ. После 
этого в верхней части экрана высвечивается рамка горизонталь¬ 
ного меню и курсор перемещается в левую часть этой рамки, 
в которую теперь можно вводить текст позиций меню. Текст 
позиции вводится после нажатия клавиши Р5. Завершается ввод 
текста этой же клавишей. Затем нужно курсор передвинуть 
вправо по рамке на требуемое место и аналогично ввести текст 
следующей позиции. 

При создании остальных компонентов (вертикального меню, 
всех типов списков и модуля ВаісН) выполняются те же операции 
вплоть до высвечивания рамок этих компонентов. Изменение 
размеров рамок (кроме списков) и их перемещение выполня¬ 
ется так же, как это описано выше для рамки заставки приклад¬ 
ной программы. Текст в позиции вертикального меню и модуля 
ВаісЬ вводится с клавиатуры, а переход по позициям осуществля¬ 
ется навигационными клавишами Вверх и Вниз. В позиции списков 
текст не вводится. 

Если ранее уже были созданы меню или списки, их можно 
выбрать из перечня, высвечиваемого при выборе соответствую¬ 
щих позиций меню йезідпе. После того, как созданы все 
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необходимые компоненты, можно приступить к назначению 
позициям меню и спискам требуемых действий или назначению 
выполнения модуля ВаісН. Установленное ранее в главной 
процедуре назначение конкретного файла БД, параметров и 
других значений с!ВА$Е IV распространяется также и на меню. 
Однако эти назначения можно изменить для каждого компонента 
прикладной программы, используя их меню: Мепи - для меню 
горизонтального и вертикального типа, ВаісЬ - для модуля ВаісЬ, 
Ы$1 - для списков. Поэтому перед присвоением позициям меню 
действий может потребоваться обращение к этим меню. 

В указанных меню ряд опций (по назначению параметров 
сШАЗЕ IV, изменению имени компонента и др.) полностью 
аналогичен опциям меню Арріісаііоп и описываться не будут. 
Другие опции являются общими для всех компонентов, а 
некоторые специфичны для определенного компонента. Рассмот¬ 
рим сначала опции, общие для всех компонентов. К ним 
относятся опции, служащие для изменения файла БД, предназна¬ 
ченного для обработки в компоненте, записи справочного текста, 
который можно высветить клавишей Г1 в активном состоянии 
компонента, ввода комамд СІВА5Е IV, которые будут выполняться 
до или после активизации компонента на экране и др. 

Опция Оѵеггісіе адеідпесі сІаіаЬазе ог ѵіеж дает возможность 
подтвердить или изменить ранее назначенный файл БД или 
использовать тот файл БД, который будет активным в момент 
работы компонента. Сначала высвечивается имя файла БД и 
индексных файлов, ранее назначенное компоненту. Для измене¬ 
ния этих назначений заполняются графы в высвечиваемом 
шаблоне. В графе Рог іЬі* < компонент > уои тау ихе ѵаІие$ 
следует выбрать клавишей Пробел одно из трех ключевых слов: 
ІИ ЕРРЕСТ АТ кии ТІМЕ, АВОѴЕ, ЕИТЕКЕй ВЕЮѴ/. 

Первое ключевое слово позволяет назначить для обработки 
файл БД, который будет активным в момент работы компонента. 
Например, при выполнении прикладной программы сначала 
может высвечиваться список файлов БД, из которого пользова¬ 
тель выбирает требуемый файл, а затем появляется меню 
операций с этим файлом. Второе ключевое слово фиксирует 
назначение файла БД в главной процедуре. В этих двух случаях 
последующие графы в шаблоне на экране не заполняются. При 
выборе третьего ключевого слова графы шаблона ОаіаЬа$е/ѵіеж, 
5еі 1№ЕХ іо, ОКОЕК заполняются так же, как и в главной 
процедуре. 

Опция Ѵ^гііе Ьеір іехі (отсутствует в меню Арріісаііоп и 
ВаісЬ) служит для записи справочного текста, который высвечива¬ 
ется клавишей Р1 в активном состоянии компонента на экране в 
ходе выполнения прикладной программы. Справочный текст 
записывается с клавиатуры на полном экране (в объеме до 19 
строк). В тексте запрещаются кавычки. После записи текст 
следует сохранить клавишами СітІ-ЕпсІ. В этой опции справочный 
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текст можно ввести для компонента в целом, а для каждой 
позиции горизонтального и вертикального меню он вводится с 
помощью позиции Нет основного меню генератора прикладных 
программ. В последнем случае справочный текст для компонента 
в целом не высвечивается. 

Опция Мосіііу сіі$рІау орііоп* (отсутствует в меню ВаісЬ и 
Арріісаііоп, где аналогичные действия выполняются опцией МосІі(у 
арріісаііоп епѵігоптеггі) позволяет установить тип рамки и цвета 
элементов компонента на экране. Эти же установки переносятся 
на компоненты, которые разработаны вне генератора прикладных 
программ и вызываются из меню, например, экранные формы 
ввода и вывода информации, отчеты и т.д. 

Эти назначения перекрывают установки, выполненные в меню 
Рге$еі генератора прикладных программ, а также в опции Оі$рІау 
орііопз меню Арріісаііоп. Тип рамки включает: одиночную 
($іпдІе) и двойную линии (РоиЫе), сплошную полосу 
(РапеІ) и без рамки (Ыопе). 

Опция ЕтЬесІ с о сіе позволяет ввести команды языка сіВАЗЕ 
IV, которые выполняются в составе прикладной программы 
перед или после’активизации компонента. Для этого выбираются 
опции Веіоге (перед) или АНег (после), после чего открывается 
полный экран для ввода команд (до 19 строк). Для ввода 
большего количества команд можно предварительно создать 
процедурный модуль любой длины с расширение .ргд и вызвать 
его из прикладной программы, введя команду йО <имя 
процедуры >.ргд. 

К числу опции, специфичных для определенного типа меню, 
относится опция АНасЬ риіі-сіоѵѵп тепи$ меню Мепи, позволяю¬ 
щая прикрепить к позиции горизонтального меню вертикальное 
меню или один из списков. После выбора данной опции 
высвечивается сообщение РиІІ сіоѵѵп аззосіаіесі птепи$... Если ответ 
Ѵе$, меню или список прикрепляется, N 0 - нет. Прикрепляемое 
меню или список имеют те же атрибуты, что и горизонтальное 
меню. Следует отметить, что в данной опции устанавливается 
только возможность прикрепления меню или списка. Собственно 
прикрепление выполняется опцией Ореп а тепи позиции Нет 
основного меню генератора прикладных программ. 

В меню І.І5І имеются три опции, отражающие специфику 
данного меню. Опция Ісіепіііу Я1е$ іп Іі$і предназначена для 
ввода из текущего директория имен файлов, которые должны 
быть в списке. Для этого используется шаблон имени файла со 
знаками замещения * и ?. Например, *.сІЫ позволяет ввести 
в список из дирекюрия только файлы типа .сІЫ, а шаблон 
*.?сіх - индексные файлы типа .псіх и .тсіх. 

Опция ІсІеѵѵгіІу (іеІсІ5 іп Іізі предназначена для создания 
списка полей файла. После выбора этой опции следует ввести с 
клавиатуры имена полей, которые требуется включить в список 
или выбрать их из списка полей файла, высвечиваемого клавиша- 
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ми 5ЫН-Р1. При вводе с клавиатуры имена полей должны 
разделяться запятыми. Если не введено ни одно имя поля, то в 
список включаются все поля текущего файла БД. Если создавае¬ 
мый список полей прикрепляется к горизонтальному меню, то в 
него включаются все поля файла БД. 

Опция ІсІеіѵГііу ІіеІсІ ѵаіиез іп Іізі предназначена для создания 
списка значений поля. После выбора этой опции высвечивается 
предложение ввести имя поля, из которого составляется список 
значений. Имя поля вводится с клавиатуры или выбирается из 
списка полей текущего файла БД, высвечиваемого клавишами 
5НІЙ-Р1. Сохранение выбранных полей выполняется клавиша¬ 

ми ОгІ-Епгі. 

Для сохранения на диске активного компонента (в нем 
находится курсор, и его рамка подсвечивается другим цветом) 
выбирается опция $аѵе сиггепі (после сохранения компонент 
остается на экране, что позволяет продолжать с ним работу), для 
удаления с экрана с сохранением - опция 5аѵе сНапдез и для 
удаления без сохранения - опция АЬапсІоп сНапдез позиции Риі 
а\ѵау сиггепі. 

В процессе разработки на экране может находиться 
несколько компонентов прикладной программы (их общее 
количество определяется размером свободной оперативной 
памяти ПК), но активным может быть только один компонент. 
Передвижение курсора по компонентам (с одновременным 
переводом его в активное состояние) выполняется клавишами РЗ 
и Р4. 

Если требуется удалить с экрана сразу все компоненты 
(главная процедура не удаляется), используется опция СІеаг 
жогк зигіасе, которая удаляет последовательно все компоненты, 
высвечивая перед удалением меню с позициями: $аѵе сНапдез 
- сохранить изменения, АЬапсІоп сНапдез - без сохранения 
изменений. 

Меню Нет позволяет назначить позициям горизонтального, 
вертикального меню, модуля ВаІсН и спискам основное и 
дополнительные действия, которые будут выполняться при 
выборе позиций и списков. К дополнительным действиям 
относится, например, вывод клавишей Р1 на экран справочного 
текста, поясняющего основное действие позиции, или установка 
указателя записи файла БД перед выполнением основного 
действия. 

Перед назначением действий нужно установить курсор на 
соответствующую позицию меню или любую позицию списка 
(напомним, что всем позициям списка может назначаться только 
одно действие). Дальше для сокращения при описании назначе¬ 
ний действий позициям меню под ними будут также подразуме¬ 
ваться и списки. 

Опции позиции Нет основного меню генератора прикладных 
программ выполняют следующие функции: назначение позиции 
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меню основного действия, назначение дополнительного действия, 
ввод команд СІВА5Е IV до или после выполнения основного 
действия, выполняемого выбором позиции меню, изменение 
назначения файла БД, который будет обрабатываться при выборе 
данной позиции меню, и вывод на экран данных о текущей 
позиции меню. 

Для назначения основного действия используется опция 
СЬапде асііоп. После выбора этой опции высвечивается меню с 
описанием основных действий. В их число входят: вывод на 
экран записей файла БД в форме Вгож$е и Есііі, вывод на 
принтер или экран данных в форме отчетов или марок, выполне¬ 
ние операции с файлами БД (копирование, добавление записей 
из другого файла, копирование отдельных полей, замена 
содержимого полей, пометка записей на удаления, уничтожение 
пометок на удаление, удаление из файла помеченных записей, 
создание индексного файла, переиндексирование файла БД, 
сортировка записей с созданием нового файла, импорт внешних 
и экспорт своих файлов), выполнение программ, процедур и 
групп команд сІВАЗЕ IV, йОЗ, двоичных модулей и макроопреде¬ 
лений, назначение выполнения модуля ВаісН, не выполнение 
никакого действия (назначается по умолчанию), выход в УЦ или 
005. 

После выбора опции СЬапде асііоп высвечивается меню с 
перечнем отдельных операций и групп операций. Назначение 
выполняется выбором требуемой операции. Операция Вготе 
выводит на экран данные из файла в табличной форме. После 
выбора этой опции высвечивается шаблон с графами, определяю¬ 
щими структуру и форму таблицы Вгожзе. В графу РІЕЮ5 
вводятся имена полей для включения в экранную форму Вгоѵѵзе. 
Имена полей можно набрать с клавиатуры, разделяя их запяты¬ 
ми, или выбрать из списка, высвечиваемого клавишами 5ЫЙ-Р1. 
Область для ввода имен полей имеет длину 68 символов. Если 
имена полей не вводятся в шаблон, то в экранной форме Вгожзе 
высвечиваются все поля. Выбор имен полей из списка выполня¬ 
ется клавишей Епіег. 

В графу РІІ.ТЕК можно ввести запрос и (или) фильтр для 
отбора требуемых записей из файла БД. При вводе имени 
запроса перед ним следует поместить/ ключевое слово РІІ.Е. В 
таблице Вгожзе с большим количеством полей можно установить 
число смежных полей, начиная с первого, которые фиксируются 
слева на экране при движении курсора по колонкам таблицы. 
Это число указывается в графе Ріеісіз іо ЮСК оп зсгееп (О 
означает, что нет фиксированных полей). Иногда, при обработке 
полей записи файла БД, желательно во избежание порчи данных 
установить защиту от обновления для некоторых полей. Графа 
РКЕЕ2Е есііі Іог (іеЫ позволяет указать поле, которое можно 
обновлять, а для остальных полей устанавливается запрет на 
редактирование. Если в эту графу не введено ни одного имени 
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поля, то будет разрешено редактирование всех полей (в том 
числе ранее защищенных от редактирования). Кроме этого, 
можно также установить еще несколько режимов защиты 
информации по отношению ко всему файлу в целом. Установка 
в графу АІІож гесогсі А00 клавишей Пробел значения Ѵе$ 
разрешает и Ио запрещает добавление записей в конец файла 
БД. Аналогично в графе АІІож гесогсі ЕРІТ устанавливается 
разрешение или запрет обновления, а в графе АІІож гесогсі 
РЕІ.ЕТЕ то же для удаления записей в файле БД. 

Для удобства работы с данными в полях файла БД в 
таблице Вгожзе можно установить в графе Махітит соіитп 
>УЮТН требуемую ширину высвечиваемой колонки каждого поля 
независимо от ширины, принятой при создании файла БД. 

Ввод и вывод информации из файлов БД можно выполнять 
не только в стандартной форме Вгожзе, но и в экранных 
формах, разработанных пользователем. Такую ранее разработан¬ 
ную форму можно использовать вместо стандартной формы ЕсііІ, 
которая является альтернативой формы Вгожзе (переключение 
осуществляется клавишей Р2). В графу РОВМАТ (Ме вводится имя 
экранной формы (с расширением Аті), которая будет высвечи¬ 
ваться вместо стандартной формы ЕсШ. Имя экранной формы 
вводится с клавиатуры или выбирается из списка, высвечиваемого 
клавишами 5ЫЙ-Р1. Можно также создать новую экранную 
форму, выбрав позицию <сгеаіе> этого списка. Можно также 
использовать ранее использовавшуюся структуру стандартной 
экранной формы Вгоѵѵзе. Для этого служит графа ІІ5Ѳ РВЕѴІОІІ5 
Вго\ѵ$е ІаЫе. Значение Ѵе5 назначает ранее использовавшуюся 
экранную форму Вгожзе, а N 0 позволяет создавать новую. Графа 
Р0И-0>^ гесогсі аЙег ирсіаіе устанавливает режим перестановки 
записи в файле БД в соответствии с его новым значением 
индекса (Ѵе$) после ее обновления или режим без переста¬ 
новки обновленной записи (N 0 ). В нескольких графах шаблона 
работы с таблицей Вготе можно установить опции, определяю¬ 
щие внешний вид этой экранной формы. В графе Оі$рІау Вгоѵѵхе 
МЕРШ можно удалить (N 0 ) или оставить (Ѵе$) меню экранной 
формы Вгож$е, в графе СОМРКЕ55 сіі$рІау - сжать заголовок 
экранной формы (Ѵе$), что позволяет высвечивать в таблице 
Вгож$е на 2 записи больше, чем обычно, в графе КЕЕР ітаде оп 
ехіі - оставить (Ѵе5) или удалить (N 0 ) экранную форму после 
завершения сеанса операций с файлом БД. Здесь и ниже выбор 
альтернативных значений граф шаблонов осуществляется клави¬ 
шей Пробел. 

Операция Есііі выводит на экран по одной записи файла БД 
в альтернативной стандартной форме, в которой поля расположе¬ 
ны по вертикали. При назначении этой операции можно также 
задать с помощью шаблона ряд вариантов (опций) ее использо¬ 
вания. Эти опции в основном совпадают с опциями формы 
Вгож$е с небольшими отличиями. В графе Мосіе клавишей 
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Пробел устанавливается общий режим работы с формой Есііі: 
обновление - Есііі и добавление - АРРЕЬЮ. В последнем случае 
задействуются только опции Рогтаі и РіеІсЬ. В режиме Есііі 
можно также задать условия отбора записей: в графе 5СОРЕ - 
диапазон обрабатываемых записей файла БД, в графе РОК - 
условие отбора записей, в графе >УНІІ-Е - условие, определяю¬ 
щее конец обработки записей. Диапазон обрабатываемых записей 
устанавливается ключевыми словами: КЕСОКР <И> - одна 

запись с номером Ы, ЫЕХТ <И> - N записей, начиная с 

текущей, АІ.І. - все записи и КЕ$Т - записи, начиная с текущей 
до конца файла. 

Опция Оізріау ог ргіпі меню СЬапде асНоп позволяет 
назначить операцию вывода отчета или марки, установить 
внешнее устройство этого вывода, а также некоторые опции 
вывода на экран файла БД. Для назначения вывода на печать 
выбирается опция Керогі меню, высвечиваемого после выбора 
опции Різріау. После этого высвечивается шаблон, в который 
вводятся данные, необходимые для вывода отчета. В графу 
РОКМ паше вводится имя ранее разработанного отчета. Обычно 
сформированный отчет уже включает все элементы для его 
вывода, в том ^исле условия для отбора записей, структуру 
заголовка страницы и т.д. Если же в отчет не включено условие 
отбора записей, то его можно ввести из разрабатываемой 
прикладной программы. Для этого служат графы шаблона РІІ.ТЕК, 
5СОРЕ, РОК и \ѴННЕ, которые заполняются так же, как и для 
экранных форм Вгожзе и ЕсІіі. В графе НЕАРІИС можно задать 
ввод дополнительного заголовка, который будет печататься в 
первой строке каждой страницы отчета (в этом заголовке 
нельзя использовать двойные кавычки), а в графе Неабіпд (огтаі 
- вывод в заголовке даты и номера страницы. Для этого 
клавишей Пробел выбирается значение ІЫСК.ІШЕ ОАТЕ АИО РАСЕ 
(при выборе РІ.АІЫ дата и номер страницы не выводятся). 

Кроме этого, в графе Керогі (огтаі можно задать (также 
клавишей Пробел) вывод на печать всех записей (РШЛ. йЕТАП) 
или только строк, содержащих итоги и подытоги (51ІММАКѴ 
ОИЬУ). В графе Ве(оге ргіпііпд можно установить этой же 
клавишей перевод страницы перед печатью (5КІР ТО ИЕ\У 
РАСЕ) или печать без предварительного перевода страницы (ОО 
ИОТ ЕІЕСТ). В графе $епсІ оиіриі іо устанавливается внешнее 
устройство, на которое должен выводиться отчет: принтер 
(РКІИТЕК), файл на диске (РІ5К РНЕ), экран (5СКЕЕЫ), или по 
запросу пользователя в ходе выполнения программы (А$К АТ 
кии тіме). В последнем случае в ходе выполнения программы 
высвечивается вертикальное меню с тремя позициями, указываю¬ 
щими вывод на принтер, диск или экран. 

Опция І.аЬеІ$ позволяет назначить позиции меню вывод 
марки. После выбора этой опции высвечивается шаблон с 
графами, в которые требуется ввести необходимые данные. 
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В шаблоне марки графы в основном те же, что и в шаблоне 
отчета, хотя несколько граф, специфичных для отчета, отсутству¬ 
ют. Одна графа - Ргіпі 5АМРІ.Е - специфична только для марки, 
в ней устанавливается пробный вывод марки (значение Ѵе$) 
перед печатью. 

Опция 0і$р1ау/1і$і определяет некоторые параметры вывода 
на экран записей файла БД. Эти параметры также требуется 
ввести в графы высвечиваемого после выбора опции шаблона. В 
их число входят выводимые поля (Ріеіск), условия отбора 
записей файла БД (РИТЕВ, 5СОРЕ, РОК и Ѵ/ННЕ) и внешнее 
устройство вывода ($епс1 оиіриі іо). Эти графы заполняются так 
же, как и в шаблонах экранных форм (операций) Вгожзе, Есііі 
и др. Кроме них включены графа Раи$е аі ІиІІ раде/хсгееп для 
установки паузы после вывода 20 строк (значение Ѵе$) или 
вывода без перерыва (N 0 ) и графа Іпсіисіе РЕСОКО ИІІМВЕВ5 
для установки вывода номера записи (значение Ѵе$). 

Опция Регіогт (ііе орегаііоп меню СНапде асііоп дает 
возможность назначить позиции меню или модуля ВаісН приклад¬ 
ной программы одну из операций с файлами БД. После выбора 
этой опции высвечивается меню, позволяющее выбрать конкрет¬ 
ную операцию. Операция копирования файлов назначается 
выбором опции Рііе сору, после чего в высветившийся шаблон 
следует занести имена файлов источника (Сору ЯІе) и мишени 
(іо ЯІе). 

Для добавления записей из заданного файла (или из 
массива переменных) в активный файл БД в момент выполнения 
прикладной программы (опция АсЫ гесогсЬ Ігот ЯІе) требуется 
ввести имя файла (массива переменных) - источника в графу 
шаблона АсЫ гесогсіз РВОМ ЯІе/аггау, а в графе іуре выбрать 
одно из ключевых слов, определяющих тип файла или массив 
(включая внешние файлы): ОВР, СІВА5Е II, Р>Ѵ2, ВРЭ, 

ОЕЫМІТЕО, 50Р, 5ѴІ.К, Ѵ/К5, АВВАѴ (ключевое слово массива 
переменных). Если выбирается тип ОЕЫМІТЕО, то требуется 
ввести знак разделителя (по умолчанию принимаются двойные 
кавычки). В графу РОВ вводится условие, определяющее 
отбираемые записи для добавления в файл БД. Копирование 
заданных полей активного файла в момент выполнения приклад¬ 
ной программы в другой файл (или в массив переменных) 
назначается выбором опции Сору гесогсі$ іо ЯІе. Для этого в 
графы высветившегося шаблона вводятся данные, аналогичные 
операции добавления: имя файла БД или массива переменных 
(Сору гесогсІ5 ТО ЯІе/аггау), тип файла, а также условия отбора 
копируемых полей и записей (РІЕЮ5, РИТЕВ, 5СОРЕ, РОВ и 
^НИЕ). 

Замена содержимого полей файла БД осуществляется 
выбором опции 5иЬ$іііиіе ЯеЫ ѵаіиез. При этом в графы шаблона 
следует ввести имена полей, в которых будет заменяться 
содержимое (ТНе ЯеЫ патесі), и новые значения этих полей 
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(мгііЬ 1ЬІ$ ѵаіие). В графе АОРІТІѴЕ устанавливается режим 
изменения содержимого поля (только для Мето поля): 
замещение (значение N 0 ) или добавление к уже имеющемуся 
содержимому поля (Ѵе$). Кроме этого, можно указать условия 
отбора записей, для которых выполняется операция замены 
содержимого полей, введя данные в уже не раз упоминавшиеся 
графы $СОРЕ, РОК и ^НИЕ. 

Пометка записей на удаление выполняется выбором опции 
Магк гесогсі Іог сіеіеііоп. В шаблон этой опции можно ввести 
только условия отбора записей для этой операции. Если эти 
условия не введены, то помечаются все записи файла БД. 
Аналогично осуществляется уничтожение этих пометок. 

Для того, чтобы сгенерировать индексный файл, выбирается 
опция Сепегаіе іпсіех. После выбора этой опции высвечивается 
шаблон с графами для ввода следующих данных: выражение для 
создания индекса (Іпсіех КЕѴ ехрге$$іоп), которое может 
включать любое количество полей (нельзя индексировать Мето 
поля) и допустимые с ними в СІВА5Е IV действия (кроме логи¬ 
ческих), установку на включение в индексный файл только 
первой записи с повторяющимся значением индекса (Ѵе$) или 
включение всех записей (N 0 ) (Іпсіех і\г*1 кеу оссигапсе опіу), 
установку индекса в убывающем порядке (Ѵе$) (Іпсіех іп 
0Е5СЕН0ІНС огсіег), имя индексного файла (только для типа 
.псіх), который требуется сгенерировать (ІЫРЕХ Іііе), имя 
указателя индекса в множественном индексном файле (для типа 
МйХ) (ТА©) (если не создается индексный файл типа .псіх), 
имя .МйХ файла, указатель которого введен в предыдущей 
графе (МйХ Іііе). Переиндексация файла БД осуществляется 
выбором опции Кеіпсіех сІаіаЬазе. Это требуется в том случае, 
если в файл БД были добавлены или изменены записи при 
закрытом индексном файле. 

Сортировка записей с созданием нового файла БД назнача¬ 
ется выбором опции РНузісаІіу $оіі сІаІаЬазе. В шаблон этой 
опции заносятся данные: имя нового отсортированного файла 
(ТО іііе), имена полей в порядке, определяющем сортировку 
записей ($огі НЕЮ5), порядок сортировки - возрастающий 
(А5СЕИОІИО) или убывающий (0Е5СЕИ0ІН©) ($ог* огсіег), 
различение (ДОЕ СА5Е) или не различение (ІОЫОКЕ СА$Е) 
прописных или строчных букв. Кроме того, вводятся условия 
отбора записей для сортировки в упоминавшиеся стандартные 
графы 5СОРЕ, РОК и Ѵ/НИЕ. 

Опции Ітроіі іогеідп Іііе и Ехрогі іогеідп Іііе позволяют 
назначить позиции меню прикладной программы импорт файлов 
из других СУБД и экспорт своих файлов БД. При назначении 
импорта в графы шаблона следует ввести имя файла (Ргот Іііе) 
и выбрать его тип (оІ Іуре). В шаблон экспорта также нужно 
ввести имя файла БД (То іііе) и тип файла. Кроме того, в этот 
шаблон можно ввести список полей файла БД, которые перено- 
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сятся в экспортируемый файл (Ріеісіз), и условия отбора записей 
для экспорта (5СОРЕ, РОК и Ѵ/ННЕ). 

Кроме операций с файлами, позиции меню прикладной 
программы можно также назначить выполнение команд сІВАЗЕ IV 
и 005. Для этого служит опция Кип ргодгат. После выбора этой 
опции высвечивается меню, позволяющее назначить выполнение 
программы (процедуры) сІВАЗЕ (сІВА5Е III и сІВАЗЕ IV), 
написанной на языке сІВАЗЕ и 50І_, группы команд сІВАЗЕ, 
команды (утилиты, программы) 005, двоичного модуля (с 
расширением .Ьіп), макроопределения, а также выполнение 
модуля ВаісН. 

Для назначения выполнения программы (модуля) сІВАЗЕ 
выбирается опция Оо сІВАЗЕ ргодгат и заполняется шаблон. В 
графу Ргодгат вводится имя сІВАЗЕ программы (расширение 
.сІЬо, .ргд или .рг$), а в графу Рагатеіег$ - параметры для этой 
программы. Опция Іпзегі сІВАЗЕ сосіе используется для назначе¬ 
ния позиции меню выполнения группы команд. После выбора 
этой опции появляется экран, на котором можно записать до 19 
строк команд сІВАЗЕ. Назначение выполнения команд (программ, 
модулей, утилит) РОЗ осуществляется опцией Кип 005 ргодгат, 
после выбора которой высвечивается шаблон с графами для 
ввода имени команды (Ргодгат) и ее параметров (Рагатеіек). 
Например, при назначении команды 005 СНК05К можно 
передать параметр /I. Опция ЬоасІ/саІІ Ьіпагу Іііе служит для 
назначения загрузки или выполнения двоичного модуля (напи¬ 
санного на Ассемблере) с расширением .Ьіп и имеет шаблон, 
аналогичный предыдущей опции. 

Для назначения позиции меню выполнения созданного ранее 
макроопределения используется опция РІау Ьаск тасго, после 
выбора которой высвечивается окно для ввода имени макроопре¬ 
деления. 

Опция Ехесиіе ВАТСН ргосе$$ назначает выполнение группы 
операций модуля ВаісЬ. После выбора этой позиции требуется 
ввести в окно имя модуля ВаІсН. 

В меню прикладных программ обычно предусматривается 
выход в РОЗ, УЦ сІВАЗЕ IV или в вызывающую программу 
(процедуру). Назначение таких операций выполняется с помо¬ 
щью опции Оиі і. После выбора опции высвечивается меню с 
двумя позициями - для выхода в вызывающую программу 
выбирается Кеіигп іо саіііпд ргодгатш, а для выхода в РОЗ - 
Оиіі іо РОЗ. 

Как уже упоминалось, система меню прикладных программ 
может строиться в виде вложенных многоуровневых структур 
меню вертикального или горизонтального типа. Для реализации 
такой структуры используется операция открытия меню, которая 
назначается опцией Ореп а тепи. После выбора этой опции 
высвечивается шаблон с двумя графами, позволяющими выбрать 
тип и ввести имя открываемого меню или списка. Если позиции 
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прикладного меню не требуется назначать какую-либо операцию, 
то используется опция Тех! (по асііоп), которая высвечивает 
текст позиции и не выполняет никаких действий (по умолчанию 
назначается всем позициям меню). Такие позиции часто использу¬ 
ются для пояснения выполнения нижеследующих позиций 
вертикального меню. 

Несколько опций меню Нет позволяют, кроме основного 
действия, назначить еще и дополнительное действие. Например, 
опция Ро$іііоп гесогсі роіпіег дает возможность назначить 
установку указателя позиции записи в файле БД. После выбора 
этой опции высвечивается шаблон, в котором следует выбрать 
значения Ѵе$ или Но в графе Різріау Р05ІТІ0ИІЫС МЕИII аі 
КІІИ ТІМЕ?. Если задано значение Уе$, то при выборе позиции 
прикладного меню высвечивается вертикальное меню, позволяю¬ 
щее: найти запись по индексу, перейти к записи с заданным 
номером, а также к первой или последней записи, найти запись 
без индекса и возвратиться в предыдущее меню. Для поиска 
записи с требуемым значением индексированного поля выбира¬ 
ется позиция $ЕЕК Кесогс! (этот индекс должен быть установлен 
главным, т.е. управляющим), после чего следует ввести поиско¬ 
вое значение. Чтобы перейти к записи с заданным номером (к 
первой или последней записи), выбирается позиция СОТО Кесогс! 
и вводится номер записи (выбираются опции' Тор или ВоНот). 
Поиск по неиндексированным полям задается выбором позиции 
ЮСАТЕ КесогсІ и последующим вводом искомого значения поля 
(для символьных полей в кавычках). Возврат в предыдущее 
меню осуществляется выбором позиции Кеіигп. 

Если в графе Оігріау Р05Ш0ШЫС МЕЫ1Л аі КІІЫ ТІМЕ? 
выбрано N 0 , то в соответствующие графы шаблона можно ввести 
данные, позволяющие установить указатель записи в файле БД 
сразу после выбора позиции меню прикладной программы 
посредством поиска по индексированному и неиндексированному 
полям или по номеру записи. Эти данные аналогичны указанным 
выше. В графу 5ЕЕК (іг$і оссигапсе о( кеу вводится выражение 
для поиска по индексированному полю, в графу СОТО - номер 
записи (или ключевые слова Тор или ВоНот), в графы І.ОСАТЕ 
вводятся данные для поиска по неиндексированным полям: 
5СОРЕ - диапазон поиска, РОК - поисковое выражение, 
>УНІІ_Е - условие конца поиска. 

К числу дополнительных действий также относится назначе¬ 
ние индексного файла или указателя индекса в множественном 
индексном файле (&еа$$ідпе іпгіех огеіег). Для этого требуется 
ввести в шаблоне в графу 5еі ОКРЕК іо число, определяющее 
порядковый номер индекса в списке индексных файлов .псіх или 
указателя индекса в множественном индексном файле .тсіх, а 
также имя .тсіх файла в графе ОР. Очень полезным дополни¬ 
тельным действием является назначение ввода и вывода данных 
файла БД в окно на экране. Одновременное высвечивание в 
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окнах данных из нескольких файлов БД обеспечивает удобство 
работы с ними. Для назначения вывода в окно служит опция 
Рейпе ІодісаІ жіпсіож. После выбора этой опции требуется ввести 
в шаблон следующие данные: имя окна в графу жіпсіож НАМЕ, 
тип рамки окна - одинарная линия (5ІЫСІ.Е), двойная линия 
(ООІІВ1.Е), сплошная полоса (РАИЕІ.), определяемая пользовате¬ 
лем (СІІ5ТОМ) и без рамки (ИОНЕ) в графу Оі$рІау Ьогсіег аз, 
буквенные коды цвета стандартной и нестандартной областей 
экрана, рамки и фона (например, 6 + /Ы,ѴѴ/К,0 + устанавливает 
цвет стандартных областей экрана зелеными буквами на черном 
фоне, нестандартные области (подсвеченные поля) - белыми 
буквами на красном фоне и зеленый цвет рамки) в графу 
Соіогз, координаты левого верхнего и правого нижнего углов 
окна в графы ІІРРЕК 1.ЕРТ согпег аі гож апсі соіиѵпп и ЬОѴЕК 
КІСНТ согпег аі гож апсі соіитп. Если рамка окна задается 
пользователем, то в графу Вогсіег сЬагасіегз (Іог СІІ5ТОМ 
Ьогсіегз) следует ввести символы или их коды АЗСІІ для 
определения сторон рамки окна. Символы заключаются в 
двойные кавычки, а коды АЗСІІ в фигурные скобки. Если 
устанавливаются различные символы для сторон рамки, то они 
отделяются запятыми. 

С позицией меню прикладной программы можно связать 
справочный текст, который высвечивается клавишей Р1 при 
выборе данной позиции. Если этот текст не введен, то высвечи¬ 
вается текст, который назначен меню или списку в целом. При 
отсутствии и этого текста высвечивается сообщение N 0 Ьеір 
сІеГшесі (справочного текста нет). Справочный текст (до 19 
строк) записывается после выбора опции >Ѵгііе Ьеір іехі на 
полном экране. К справочной информации относится также текст 
сообщения (длиной до 76 символов), высвечиваемого внизу 
экрана при выборе позиции. Этот текст можно ввести после 
выбора опции Аззідпе теззаде Ііпе рготрі. Двойные кавычки 
внутри текста запрещаются. 

Кроме дополнительных действий можно ввести команды 
языка сіВАЗЕ, которые будут выполняться перед или после 
выполнения основного действия, назначенного позицией меню 
прикладной программы. Эти команды записываются на полном 
экране, который высвечивается после выбора опции ЕтЬе4 со бе 
и соответствующего ключевого слова: Веіоге (перед) или АНег 
(после). Для ввода большего количества команд можно 
предварительно создать процедурный модуль любой длины с 
расширением .ргд и вызвать его, введя команду ЭО <имя 
процедуры> .ргд. В частности, эта операция позволяет превратить 
списки в полноправные меню, когда после выбора каждой 
позиции списка можно выполнять различные действия. Для 
реализации этого можно использовать функцию ВАКО, которая 
возвращает номер позиции списка. Ее следует включить в 
команды РО СА5Е ИЛИ ІР для возвращения номера позиции 
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списка в условие, определяющее ветвление процесса дальнейше¬ 
го выполнения команд. 

Завершает список дополнительных действий опция Вура$$ 
Нет оп сопсііііоп, позволяющая задать условие, по которому 
операция, назначенная позиции меню, не будет выполняться 
после ее выбора (только для вертикального меню). В шаблон 
этой опции с графой $кір іЬі$ ііет і( требуется ввести условие 
отключения выполнения операции, назначенной позиции меню. 
Например, можно для позиции, которая обрабатывает требуемый 
файл БД, установить условие .ЫОТ. <имя файла >, означающее, 
что данная позиция пропускается, если выбирается не тот файл. 

Если при выборе позиции меню нужно обрабатывать файл 
БД, отличный от назначенного в главной процедуре или назна¬ 
ченного конкретно для этого меню, то для изменения сделан¬ 
ного ранее назначения используется опция Оѵеггісіе аззідпесі 
сІаіаЬа$е ог ѵіеж. Изменение назначения можно выполнить двумя 
способами: заменить имена файла БД и связанных с ним 
индексных файлов на новые или же задать возможность ввода 
имен файлов при выборе позиции меню прикладной программы 
в ходе ее выполнения. Для этого нужно в графе Рог іЬІ5 ііет 
уои тау и$е ѵаіиез выбрать одно из трех ключевых слов: ІИ 
ЕРРЕСТ АТ КУИ ТІМЕ, АВОѴЕ, ЕИТЕКЕО ВЕЮѴЛ Первое ключе¬ 
вое слово задает возможность назначения файла БД в ходе 
выполнения прикладной программы, второе ключевое слово 
оставляет назначение файла БД, сделанное ранее, а третье 
позволяет сделать новое назначение. В последнем случае 
требуется заполнить следующие графы шаблона: имя файла БД 
(РаіаЬазе/ѵіеж), имена индексных файлов ($еі ІИйЕХ іо), 
порядковый номер главного (управляющего) индекса или его 
имя (ОКРЕП). 

Опция $Нож ііет іпІогтаііоп меню Ііет высвечивает сведения 
об основном действии, назначенном позиции меню, в следующих 
графах: имя меню (ОЬ|есі), имя позиции меню (Ііет), имя 
файла БД (Сиггепі сіаіаЬа$е/ѵіеж) и индексного файла (и$іпд 
іпсіех), назначенного данной позиции. Если этой позиции (или 
меню) специально не назначался файл БД (индексный файл), то 
высвечивается назначение, принятое в главной процедуре. В 
графе ТЬіз ііет ѵѵіІІ высвечивается основное действие, которое 
назначено данной позиции. 

Позиция Сепегаіе основного меню генератора прикладных 
программ генерирует программу и создает для нее документа¬ 
цию. В процессе генерации программы создаются два файла с 
именами: <имя главной процедуры > .ргд и <имя главного 
меню>.ргд. Их следует хранить в одном директории для 
последующего запуска. Файлу документации присваивается имя 
главной процедуры и расширение .сіос. После выбора позиции 
Сепегаіе высвечивается вертикальное меню с опциями: Ведіп 
депегаііпд - генерация программы или создание документации в 
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зависимости от выбора файла генерации (шаблона) в следую¬ 
щем меню, Зеіесі іетріаіе - назначение шаблона для создания 
программы или документации. По умолчанию принимается 
шаблон МЕНІІ.СЕЫ для генерации программы, но можно выбрать 
другие шаблоны - ООСІІМЕМТ.ОЕИ для создания документации 
или СШІСКАРР.СЕН для генерации стандартной прикладной 
программы (при этом текущим компонентом должна быть 
главная процедура, т.е. в основном меню должна высвечиваться 
позиция Арріісаііоп). 

Опция йізріау сіигіпд депегаііоп позволяет высвечивать 
программу или документацию в ходе их генерации. После 
генерации документации или программы их можно отпечатать в 
режиме ввода команд с клавиатуры командой Туре <имя 
программы или документации > оп ргіпіег или из меню Ргіпі 
текстового редактора. 

Позиция Ехіі основного меню генератора прикладных 
программ служит для выхода в УЦ с сохранением выполненных 
изменений или без сохранения и имеет прикрепленное верти¬ 
кальное меню с двумя опциями. Первая опция - 5аѵе аІІ сЬапдез 
апсі ехіі - сохраняет все компоненты прикладной программы, 
находящиеся в памяти, и прекращает сеанс работы с генерато¬ 
ром. Обычно промежуточное сохранение изменений с целью 
последующей работы над прикладной программой выполняется 
с помощью позиции $аѵе сиггепі в меню разработки компонен¬ 
тов прикладной программы Мепи, ВаісЬ или Можно 

сохранить разработанную прикладную программу под другим 
именем для последующей модификации или адаптации примени¬ 
тельно к другим задачам. Вторая опция - АЬапсІоп аІІ сЬапдез 
апсі ехіі - обеспечивает выход без сохранения последних 
изменений. На диске остаются ранее сохраненные версии 
прикладной программы. Для подтверждения выхода без сохране¬ 
ния требуется выбрать Ѵе$, после чего выполняется возврат в УЦ 
или в командный режим в зависимости от того, откуда был 
осуществлен вход в генератор прикладных программ. Если 
выбирается N 0 , то осуществляется возврат в основное меню 
генератора без изменения состояния разрабатываемых компонен¬ 
тов. 

После того как прикладная программа создана и отлажена, 
ее можно запустить из УЦ, выбрав ее имя в окне генератора. 
После этого высвечивается меню с позициями на запуск програм¬ 
мы (Кип ргодгатт) или ее модификации (Мосіііу ргодгатт). 

Для закрепления прочитанного материала попробуйте с 
помощью генератора прикладных программ создать простую 
программу, позволяющую пользователю работать с файлами БД 
нашего примера и выполнять действия по вводу и обновлению 
записей, отбору записей и выводу на печать отчета. В программу 
будут включены ранее рассмотренные файлы экранных форм 
МР1, МР2, МРЗ, МР4, запросы М015, МОІб и отчет МК1. 
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Прикладная программа состоит из главной процедуры и 
вызываемых модулей. Сначала нужно создать главную процедуру. 
Для этого выберите позицию <сгеаіе> окна Арріісаііопз, а в 
высветившемся окне - позицию Арріісаііоп; Сепегаіог и нажмите 
Епіег. На экране появится шаблон Арріісаііоп сіеііпіііоп для 
описания главной процедуры, в который нужно ввести приведен¬ 
ные ниже данные: 

Арріісаііоп пате (имя главной процедуры) - МАѴТО; 

Резсгірііоп (описание) - Программа ведения БД; 

Маіп тепи іуре (тип главного меню) - РОР-ІІР; 

Маіп тепи пате (имя главного меню) - МР1; 

РаіаЬазе/ѵіеж (файл БД/выборка) - МЕШ1. 

Все данные вводятся с клавиатуры, за исключением типа 
главного меню, которое выбирается клавишей Пробел. Для 
сохранения данных о главной процедуре нажмите клавиши 
ОгІ-Епб. После сохранения данных высвечивается стандартная зас¬ 
тавка с текстом, начинающимся с фразы ТНіз із ап АРРЫСАТЮЫ 
ОВ.ІЕСТ..., его можно стереть и ввести свой, подобный показан¬ 
ному ниже. 


Прикладная программа АѴТО 
Дата создания: 25.09.1989 г. 
Разработчики: Б.Романов, А.Кушниренко 


Для того чтобы окно такого типа появлялось при запуске 
Вашей программы МАѴТО, нажмите клавишу РІО, в меню 
Арріісаііоп выберите позицию Різріау зідп-оп Ьаппег и в опции 
йізріау (гате аз "зідп-оп Ьаппег" а* гип ііте (высветить на 
экране заставку при запуске программы) введите ѴЕ5. 

После разработки прикладной программы можно сгенериро¬ 
вать на нее документацию, в которой содержатся данные об 
авторах программы, права на копирование и версия пакета 
сІВА$Е IV. Эту информацию можно также ввести в заставку 
разрабатываемой программы (заметим, что данные вводятся не 
в текущую, а только в последующую разрабатываемую програм¬ 
му). Сначала выберите опцию Есііі ргодгат Ьеасіег соттепіз 
меню Арріісаііоп, после чего высветится окно с позициями 
Арріісаііоп аиіНог, СоругідНі поіісе и сІВазе, в которое введите 
данные: автор программы (Арріісаііоп аиіНог); авторские права 
(СоругідЬі поіісе), например "Разрешено копирование"; версия 
СІВА5Е (с!ВА$Е ѵегзіоп), например "сІВАЗЕ IV версия 1.0", и 
нажмите клавиши СігІ-Епб. 

Для сохранения главной процедуры выберите позицию 5аѵе 
сиггепі арріісаііоп сіеііпіііоп меню Арріісаііоп, которое, напомним, 


125 





как и все меню активизируется клавишей РІО. Теперь создайте 
вертикальное (Рор-ир) меню прикладной программы, в котором 
будут записаны названия выполняемых операций. Для этого 
перейдите в меню Резідп и выберите позицию Рор-ир. Справа 
на экране высветится окно имен вертикальных меню. Выберите 
позицию < сгеаіе > и нажмите клавишу Епіег. Появится шаблон 
для ввода данных об этом меню: имени, описания и сообщения, 
которое будет высвечиваться внизу экрана при переходе на 
это меню. Введите в графу Иате (имя) - МР1, а в графу 
Оезсгірііоп (описание) - "Вертикальное меню". В графу Меззаде 
Ііпе рготрі (сообщение) можно ничего не вводить. Для 
сохранения описания вертикального меню нажмите клавиши 
ОгІ-ЕпсІ. 

В центре экрана появится вертикального меню с пустыми 
позициями. Нажав клавиши 5ЫН-Р7, можно навигационными 
клавишами изменить размеры рамки меню так, чтобы ввести в 
него текст позиций, показанный ниже (новые размеры нужно 
зафиксировать клавишей Епіег): 


БАЗЫ ДАННЫХ 


Информация о водителях 
Автомобили 
Перевозки грузов 
Технические характеристики 

ОТБОР данных по перевозкам 


ВЕДОМОСТЬ расхода горючего 


Выход из задачи 


Позиции меню, составляющие смысловые группы, для 
улучшения восприятия можно отделить двойными или одинарны¬ 
ми линиями, которые рисуются так же, как и при разработке 
марок: при нажатии клавиш АІ1-205 - двойная линия и АИ-196 - 
одинарная линия. После того как введен текст позиций меню, им 
нужно назначить действия, которые будут выполняться при 
выборе этих позиций. Например, требуется, чтобы при выборе 
позиции "Информация о водителях" был открыт файл БД МІШ1, 
подключен файл экранной формы МР1 и высвечивалось содержи¬ 
мое полей БД в этой форме. Для этого установите курсор в 
позицию "Информация о водителях" и выберите позицию 
Оѵеггісіе аззідпес! сІаіаЬазез ог ѵіеѵѵ меню Нет, в высветившемся 
окне введите имя файла БД, который будет использоваться при 
выборе данной позиции меню. Переместите курсор в позицию 
окна Рог 1Ыз Нет уои тау изе ѵаіиез и нажатием клавиши 
Пробел выберите опцию ЕНТЕКЕР ВЕЮ\Ѵ, затем в нижней 
позиции РаіаЬазе/ѵіеж введите имя файла - МВР1, а в позиции 
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ОПОЕК имя главного индекса - РАМ и нажмите СігІ-ЕпсІ для 
сохранения введенных данных. 

После установки файла БД нужно назначить выполняемое с 
этим файлом действие. Допустим, что для данной позиции нужно 
назначить просмотр информации в ранее разработанной экранной 
форме МР1. Для этого выберите позицию СНапде асііоп, затем 
в высветившемся вертикальном меню - позицию Есііі Іогт 
(асМ, беіеіе, ебі і). Появится шаблон для ввода параметров 
команды ЕсНі/Аррепсі. В графу РОКМАТ Іііе введите МР1 (имя 
файла экранной формы), в графе Мосіе с помощью клавиши 
Пробел выберите опцию Есііі (разрешено редактирование). 
Другие значения в этом шаблоне менять не надо. Для сохране¬ 
ния всех установленных в шаблоне значений опций нажмите 
клавиши ОН-Еп 6. 

Кроме действий, каждой позиции меню можно назначить 
высвечивание в нижней строке экрана сообщения, которое будет 
появляться при перемещении на нее курсора при эксплуатации 
сгенерированной прикладной программой. Для этого выберите 
позицию Аззідп те$$аде Ііпе рготрі меню Нет, после чего 
высветится окно, в которое с клавиатуры введите текст, напри¬ 
мер "Информация из МВ01", и нажмите клавиши ОгІ-ЕпсІ. 

Для назначения действий следующей позиции нужно 
переместить на нее курсор. Перемещение по вертикальному 
меню осуществляется навигационными клавишами Вверх и Вниз. 
Для этого нужно клавишей Е$с убрать меню Нет, установить 
курсор на нужную позицию меню и снова активизировать меню 
клавишей РІО. 

Есть другой, более короткий способ перемещения курсора, 
без удаления меню Пет - с помощью клавиши Рдйп. При этом 
название текущей позиции создаваемого меню можно увидеть 
в нижней строке экрана. Для позиции "Автомобили" выполните 
те же операции по открытию файла МВР2, установке главного 
индекса Ы_2, подключению экранной формы Р2 и назначению 
высвечивания сообщения в нижней строке экрана "Информация 
из МВР2". 

Для позиции меню "Перевозки грузов" будут использованы 
файл МВОЗ, главный индекс И_2, файл экранной формы МРЗ 
и информационное сообщение "Информация из МВРЗ", а для 
позиции "Технические характеристики" - файл БД МВР4, главный 
индекс МАК, экранная форма МР4 и информационное сообщение 
"Информация из МВР4". 

При назначении действий позиции меню "ОТБОР данных по 
перевозкам" нужно установить выполнение запроса на отбор 
данных по перевозкам, который ранее был сформирован под 
именем М015, и высвечивание данных в форме Вгоѵѵзн. Для 
этого выберите позицию Оѵеггібе аззідпесі сІаіаЬазез ог ѵіеѵѵ 
меню Пет, в опции Рог іНіз ііет уои тау ихе ѵаіиез установите 
ЕИТЕКЕР ВЕЮѴ/, а в нижней позиции ОаіаЬа$е$/ѵіе\ѵ сведите 
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имя файла запроса на выборку М015.яЬе и нажмите СігІ-ЕпсІ. 
Заметим, что имя выборки надо обязательно указывать с 
расширением .яЬе. В противном случае имя выборки будет 
воспринято как имя файла БД, в результате чего высветится 
сообщение, что такой файл не найден. Затем, как и для 
предыдущей позиции, нужно назначить форму вывода данных. 
Пусть это будет стандартная форма Вгожзе. Для этого выберите 
позицию СНапде асііоп меню Нет, а из высветившегося меню - 
позицию Вгожзе (асісі, сіеіеіе, есііі). Установленные по умолча¬ 
нию параметры команды Вготе изменять не надо, поэтому 
сразу нажмите ОН-ЕпсГ Можно также назначить этой позиции 
информационное сообщение ''Отбор данных ло перевозкам на 
расстояние свыше 300 км", отражающее содержанию запроса 
М015. 

Позиции "ВЕДОМОСТЬ расхода горючего" нужно назначить 
вывод отчета МК1. Для этого в меню Нет выберите позицию 
СЬапде асііоп, в высветившемся вертикальном меню - позицию 
Різріау ог ргіпі, а затем позицию КерогТ в меню следующего 
уровня. Появится окно-шаблон с графами для установки ряда 
параметров отчета. В позицию РОКМ введите имя созданного 
файла отчета М&1, в позиции $епсІ оиіриі іо выберите клавишей 
Пробел параметры 5СКЕЕЫ (экран), ОІ5К РІІ.Е (файл на диске) 
или РКІИТЕК (принтер) в зависимости от того, куда Вы собирае¬ 
тесь выводить сгенерированный документ, в позиции Керогі 
(огтаі выберите значение РиІІ сіеіаіі (для вывода всех записей) 
и в позиции Веіоге ргіпііпд - значение йО ЫОТ ЕІЕСТ ( отмена 
перевода страницы перед печатью). Кроме этого, нужно 
назначить файл или выборку, данные из которых будут выводить¬ 
ся в отчет. Для этого, как и при назначении в предыдущей 
позиции, выберите позицию Оѵеггісіе адеідпесі 4аіаЬа$е$ ог ѵіеж 
меню Ііет, в опции Рог іЬі$ ііет уои тау и$е ѵаіиез установите 
клавишей Пробел значение ЕЫТЕКЕО ВЕЬО^Ѵ, а в поле ОаіаЬа$е$/ 
ѵіеж введите имя файла запроса на выборку МСМб.яЬе и 
нажмите СігІ-ЕпсІ. Как и для предыдущих позиций можно 
назначить информационное сообщение, например "Выводится 
отчет МК1". 

Последовательность операций по назначению действия 
последней позиции "Выход из задачи" аналогична предыдущей. 
Сначала установите курсор на эту позицию разрабатываемого 
меню, затем выберите позицию СЬапде асііоп меню Ііет 
генератора прикладных программ, а в высветившемся меню 
второго уровня - позицию Оиіі (выход из программы). Наконец, 
в меню третьего уровня определите, куда возвращаться. Для 
возврата в вызвавшую программу выберите позицию Кеіигп іо 
саіііпд ргодгатт - в нашем случае это УЦ. После выбора этой 
позиции высветится окно, в котором нужно подтвердить назначе¬ 
ние клавишами СігІ-ЕпсІ или отказаться от него клавишей Е$с. 
Для этой позиции также не будет лишним назначить информаци- 
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онное сообщение, поясняющее, куда передается управление 
после завершения работы с прикладной программой ''Выход в 
Управляющий Центр". 

После того как вертикальное меню сформировано, надо 
сохранить введенные данные по его определению, выбрав 
позицию $аѵе сиггепі тепи меню Мепи. После этого можно 
генерировать прикладную программу. Сначала клавишами РЗ/Р4 
установите курсор на заставку прикладной программы. Затем 
выберите позицию Ведіп депегаііпд. Начнется генерация текста 
прикладной программы, который будет записан в файл с именем 
МЛѴТО и расширением .ргд (МАУТО.ргд). Для выхода из 
генератора прикладных программ выберите позицию $аѵе аІІ 
сЬапдез апсі ехіі меню Ехіі. 

Запуск созданной программы осуществляется выбором имени 
программы в окне Арріісаііоп^ панели УЦ. После этого высвечи¬ 
вается горизонтальное меню с позициями Лип арріісаііоп 
(Запуск программы) и Мосіііу арріісаііоп (Модификация 
программы), из которых нужно выбрать первую. Затем высвечи¬ 
вается предупреждение Аге уои 5иге уои */апі іо гип іЬі$ 
арріісаііоп? (Вы действительно хотите запустить эту программу?) 
с позициями Ѵе5 и N 0 . Выбор V Ѳ5 осуществляет запуск програм¬ 
мы, а N 0 возвращает управление на панель УЦ. 


2.10. РЕДАКТОР ТЕКСТОВ 

Пакет СІВА5Е IV имеет встроенный редактор текстов, 
который в основном применяется для разработки прикладных 
программ (процедур, модулей), а также для ввода текстовых 
материалов. Редактор текста также используется при создании 
различных файлов и вызывается автоматически из различных 
точек УЦ, в том числе при вводе текстовых данных в поля 
Мето файлов БД, при разработке экранных форм и отчетов. 
При создании программ или вводе текста редактор обычно 
вызывается из УЦ в окне генератора прикладных программ. Для 
этого сначала нужно выбрать позицию <сгеаіе> в окне 
АррІісаііоп$ панели УЦ. После этого высвечивается меню с двумя 
позициями: СІВА5Е ргодгат и Арріісаііоп Сепегаіог. Первая 
вызывает редактор текста, а вторая открывает экран разработки 
прикладной программы с помощью генератора. 

Сохранение введенного текстового материала осуществляется 
с помощью меню редактора, которое описано ниже. Здесь 
отметим, что по умолчанию всем текстовым файлам присваива¬ 
ется расширение .ргд. Однако в сІВАБЕ IV для текстовых файлов 
разрешается использовать любые расширения, кроме, естест¬ 
венно, принятых для других типов файлов. Например, нельзя 
давать расширения .сІЫ, .тсіх, .!гт и др., поскольку текстовый 
файл с такими расширениями будет высвечиваться на панели УЦ 
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в соответствующем окне, а при его запуске возникнет ошибочная 
ситуация. Во многих пакетах обработки информации в качестве 
расширения для текстовых файлов принято Лхі. Это расширение 
стало стандартом для текстовых файлов. Поэтому в СУБД 
СІВА5Е IV для отличия чисто текстовых файлов от программных 
целесообразно использовать именно это расширение. 

В качестве примера в учебном каталоге РКІМЕК введены два 
учебных текстовых файла ТЕХТІ.іхі и ТЕХТ2.М, которые читатель 
может выбрать в окне Арріісаііопз панели УЦ. После выбора 
имени одного из этих файлов высвечивается горизонтальное 
меню с позициями Кип арріісаііоп и МосШу арріісаііоп. Первая 
позиция запускает на выполнение прикладную программу, 
которая записана в вызванном текстовом файле, а вторая служит 
для ввода текста или просмотра содержимого файла. 

Редактор текста имеет основное меню с позициями: Ьауоиі, 
>ѴогсІ5, Соіо, Ргіпі, Ехіі. К позиции І.ауоиі прикрепляется 
вертикальное меню, позволяющее вызвать вместо текущего 
другой текстовый файл с помощью позиции МосШу а сІіНегепі 
ргодгат. После выбора этой позиции высвечивается окно с 
предложением (Епіег ргодгат іо тосіі(у) ввести имя другого 
текстового файла. Это имя файла можно набрать с клавиатуры 
или нажать клавиши 5НІН-Р1 и выбрать имя файла из высвечен¬ 
ного списка файлов. 

Заметим, что если текстовых файлов в текущем каталоге нет 
(в нашем случае это файлы с расширением .ргд или .1x1), то 
после вызова списка клавишами 5ЫН-Р1 в нижней части экрана 
высвечивается соответствующее сообщение. Кроме того, в 
каталог можно ввести словесное описание создаваемой програм¬ 
мы (Есііі сіезсгірііоп о і ргодгат). 

Позиция $аѵе іЬі$ ргодгат сохраняет файл на диске. Перед 
сохранением высвечивается окно 5аѵе а$ для ввода нового или 
подтверждения старого имени. Это дает возможность сохранить 
копию файла под другим именем, чтобы потом использовать для 
модификации. Как и при сохранении других типов файлов, в 
окне перед именем файла нужно поместить имя диска и 
маршрут по директориям. 

Позиция Ргіпі имеет прикрепленное меню, в основном 
аналогичное меню разработки отчетов. Отличие состоит в том, 
что в данном меню имеется дополнительная опция 1.іпе питЬегз, 
позволяющая печатать номер строки в первых позициях текста. 

К позиции Ехіі прикреплено меню с позициями (первые две 
стандартные): сохранение файла на диске ($аѵе сЬапдез апсі 
есііі) и выход без сохранения (АЬапсІоп сЬапдез апсі есііі) и 
несколькими нестандартными, специфичными для / редактора 
текста. К последним относятся: сохранение выполненных 
изменений и запуск программного файла на выполнение (Кип 
ргодгат), сохранение программного файла и запуск отладчика с 
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последующим высвечиванием экрана для задания его параметров, 
включая точки прерывания и параметры, передаваемые отладчику 

(РеЬид ргодгат). 

Позиции Ѵ^огсі* и Соіо в основном совпадают с аналогичны¬ 
ми позициями в меню разработки экранных форм и генератора 
отчетов. 


2.11. РАЗГРАНИЧЕНИЕ ДОСТУПА К ИНФОРМАЦИИ И 
ЗАЩИТА ДАННЫХ 

Для создания средств защиты от несанкционированного входа 
в СІВА5Е IV и разграничения доступа к информации используется 
позиция Ргоіесі сіаіа меню Тооіз. Средства защиты включает три 
типа: 

защиту от несанкционированного входа в пакет сІВАЗЕ IV с 
использованием паролей пользователей; 

защиту доступа к файлам и полям БД; 

шифрование данных в файлах БД. 

Комплекс этих средств образует систему защиты информа¬ 
ции. Пользователи в системе защиты информации объединяются 
в группы. Каждый пользователь может входить в состав несколь¬ 
ких групп и иметь в них различные уровни доступа к информа¬ 
ции. Обычно группа связывается с множеством файлов, которые 
могут обрабатываться этой группой. Один и тот же файл может 
входить только в одно множество, связанное с определенной 
группой. 

Вход в пакет осуществляется после ввода имени пользова¬ 
теля, имени группы, в состав которой входит пользователь, и 
пароля (при вводе на экране не отображается). Если пользова¬ 
тель входит в состав нескольких групп и ему требуется получить 
доступ к файлам БД другой группы, для этого необходимо 
сначала выйти из системы и затем войти снова в составе новой 
группы. Доступ к файлам БД и полям осуществляется в соответ¬ 
ствии с присвоенным пользователю общим уровнем доступа, 
который определяет привилегии по использованию данных. 
Уровни доступа от высшего к низшему нумеруются от 1 до 8. 
Для каждого файла, связанного с определенной группой 
пользователей, назначается уровень доступа при установлении 
схемы привилегий использования конкретных файлов и полей. 

После входа в сІВАЗЕ IV определяется фактический уровень 
доступа пользователя к конкретному файлу или полю из группы 
посредством сопоставления его общего уровня доступа с 
уровнем доступа к этому файлу из схемы привилегий. Если 
уровень доступа к файлу или его полю из схемы привилегий 
выше общего уровня доступа пользователя, то данная привилегия 
ему недоступна. Схема привилегий для использования файлов БД 
в группе устанавливается посредством назначения уровней 
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доступа к различным операциям с файлами БД. Различают 
четыре типа операций: 

чтение - просмотр записей в файлах БД; 
обновление - изменение содержимого полей файлов БД; 
добавление - добавление новых записей в файлы БД; 
удаление - удаление записей из файлов БД. 

Если привилегии по использованию файлов БД не установле¬ 
ны, то по умолчанию разрешаются все операции. 

При обработке полей различаются три группы привилегий: 
разрешены все операции - чтение и запись данных в поля 
(устанавливается по умолчанию); 

разрешено только чтение - чтение (просмотр) содержимого 
поля без его изменения; 

запрещены все операции - нельзя просматривать или 
изменять содержимое поля (доступ к полю блокируется). 

При использовании средств защиты информации все файлы 
БД, включая связанные индексные файлы и поля Мето 
(файлы), автоматически шифруются и хранятся на диске в 
зашифрованном виде. При выводе выполняется их автоматическое 
дешифрование. 

Средства защиты информации в СІВА5Е IV поддерживают два 
системных зашифрованных файла: ОЬ$у$іет.сІЬ и ОЬ$у$іет.$цІ 
(в зависимости от типа используемого командного языка - 
СІВА5Е IV или 501.), которые содержат данные по системе 
защиты, включая имя пользователя, учетное имя пользователя, 
пароль, групповое имя и общий уровень доступа. Доступ к этим 
файлам осуществляется по специальному паролю, известному 
администратору системы. Этот пароль назначается один раз при 
установке системы СІВА5Е IV. 

Данные по защите информации и доступу пользователей 
устанавливаются и изменяются администратором. Средства 
защиты могут использоваться в однопользовательском режиме и 
обязательно в многопользовательском режиме работы СІВА5Е IV, 
в том числе и при работе в среде ЛВС. При первоначальном 
выборе позиции Ргоіесі высвечивается окно для ввода пароля 
администратора системы. После ввода пароля его требуется 
подтвердить, затем раскроется меню для ввода данных по 
доступу пользователя. Это меню имеет позиции ІІ$ег$, РіІе$, 
КерогТз, Ехіі 

Позиция ІІ$ег$ позволяет ввести все общие данные на 
пользователя по системе защиты информации в соответствующие 
графы таблицы: Ьодіп пате - имя пользователя, Ра$$жогсІ - 
пароль пользователя, Сгоир пате - имя группы, РиІІ пате - 
учетное имя пользователя, Ассе$ ІеѵеІ - общий уровень доступа. 
Опция $1оге и$ег ргогііе позволяет сохранить данные по доступу 
пользователя в соответствующем файле. Если предполагается 
работа с языком 50І_, то необходимо ввести имя пользователя- 
администратора 50ЮВА, имеющего доступ ко всем таблицам. 
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При вводе уже имеющейся комбинации имени пользователя, 
пароля и имени группы высвечивается предупреждение и 
предложение сделать изменения. Нельзя изменять или удалять 
имя группы. В этом случае файлы данной группы становятся 
недоступными всем пользователям. Для удаления пользователя 
требуется набрать на клавиатуре его комбинацию доступа в 
систему и затем после выбора опции редактирования выбрать 
позицию йеіеіе ихег Ігот дгоир После подтверждения пользова¬ 
тель удаляется из группы. 

Позиция РіІе$ меню Ргоіесі позволяет создать или обновить 
схему привилегий по доступу к файлам и полям в группах. 
Сначала нужно выбрать файл БД с помощью опции Ыеж Іііе из 
высвечиваемого списка в текущем или другом директории. Затем 
в опции Сгоир пате задается имя группы. В опции Рііе ассе$$ 
ргіѵііеде; назначаются уровни доступа (от 1 до 8) операциям по 
обработке файла: чтения (КеасІ ргіѵііеде), обновления данных 
(ІІрсІаіе ргіѵііеде), добавлению записей (ЕхіепсІ ргіѵііеде) и 
удалению записей (Реіеіе ргіѵііеде). Назначение привилегий по 
доступу к полям выполняется опциями позиции РіеІсІ ассе$$ 
ргіѵііедез. Опцией Ассезз Іеѵеі устанавливаются привилегии 
обработки поля: разрешены все операции (РІЛ.І.), разрешено 
только чтение (К/О), запрещены все операции (ЫОИЕ). Опцией 
Е;1аЫі;Ь ІіеІсІ ргіѵііедез назначаются уровни доступа (от 1 до 8) 
для выбранной привилегии. 

Для сохранения установленных привилегий файла, входящего 
в состав группы, выбирается опция $1оге (ііе ргіѵііедез, а для 
отмены назначений текущего сеанса - СапсеІ сиггепі епігу. 
Первоначальное назначение уровней доступа и схем привилегий 
выполняется сверху вниз по опциям вертикального меню. 
Изменение схемы привилегий осуществляется в том же порядке. 
При сохранении изменений высвечивается сообщение, напоминаю¬ 
щее о существовании старой схемы, и предложение перезаписать 
схему. После подтверждения (V) изменения сохраняются. После 
этого файлы БД и поля становятся защищенными и создаются 
копии зашифрованных файлов с расширением .сгр. При этом 
исходные файлы с расширением .сІЫ сохраняются. Установленная 
схема доступа к файлу записывается в структуру файла БД. Если 
уровни доступа и схемы привилегий для файлов и полей не 
установлены, то в системе защиты будут задействованы только 
данные по входу пользователей в систему. 

Для гарантированной защиты информации после создания 
зашифрованных копий файлов следует удалить исходные файлы 
БД. Целесообразно их предварительно скопировать на гибкие 
диски и хранить копии в защищенном месте. Чтобы система 
могла работать с зашифрованными файлами, их целесообразно 
сначала скопировать на место исходных файлов, а затем 
изменить расширение .сгр на .сІЫ. После этого надо удалить 
исходные зашифрованные файлы (с расширением .сгр). Кроме 
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того, следует заменить расширение .срі файлов Мето полей на 
расширение .сІЫ Индексные файлы шифруются в том случае, 
если они созданы вместе с зашифрованными файлами или при 
выполнении команды КЕШОЕХ с этими файлами. При выполнении 
команды РКОТЕСТ по умолчанию устанавливается команда 5ЕТ 
ЕЫСКУРТЮИ ОЫ и копии файлов также шифруются. При 
установке $ЕТ ЕИСКУРТІОИ ОРР копии не шифруются. 

Позиция Керогіз меню Ргоіесі позволяет (опция ІІхег 
іп(огтаііоп) вывести на экран информацию по доступу пользова¬ 
телей, которую можно также распечатать, если ответить (V) на 
предложение $епсІ герогі Іо 1Не ргіпіег? (У/М). Опция Рііе 
іпіогтаііоп выводит на экран информацию об уровнях и схемах 
привилегий доступа к файлам и их полям. Выбор этой опции 
высвечивает список защищенных и зашифрованных файлов БД. 
После выбора требуемого файла БД можно вывести на принтер 
информацию о доступе к нему. 

Позиция Ехіі включает опции, позволяющие сохранить все 
изменения, сделанные в ходе текущего сеанса ($аѵе), аннулиро¬ 
вать все изменения, выполненные в ходе текущего сеанса 
(АЬапсІоп) и прекратить текущий сеанс установки схемы 
доступа пользователя с сохранением всех сделанных назначений 
(Ехіі). 


Глава 3 

КОМАНДЫ И ФУНКЦИИ ЯЗЫКА сіВАЗЕ IV 

3.1. ОБЩИЕ СВЕДЕНИЯ О КОМАНДАХ 

Описанный в гл. 2 УЦ позволяет выполнять многие операции 
без знания командного языка СІВА5Е IV с помощью режима, 
управляемого меню. Однако для более полного и грамотного 
использования возможностей УЦ начинающим пользователям 
целесообразно изучать командный язык СІВА5Е IV. Это, естест¬ 
венно, относится и к пользователям, которые не удовлетворяются 
тем, что дает УЦ, и хотят более глубоко освоить пакет 
сІВАЗЕ IV. Кроме того, командный язык позволяет глубже понять 
принципы работы пакета и овладеть программированием задач, 
являющимся высшим уровнем освоения СУБД. 

В данной главе описываются команды и функции сІВА$Е IV, 
объединенные в функциональные группы примерно в той 
последовательности выполняемых ими действий, которая соответ¬ 
ствует отмеченным в гл. 2 этапам технологии разработки 
информационных задач. Команды будут сопровождаться примера¬ 
ми, которые в основном ориентированы на их выполнение в 
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командном режиме. После овладения командным языком можно 
перейти к главе 5, где на конкретных примерах показывается, 
как создавать программы на языке сІВАЗЕ IV. 

Как уже отмечалось, команды языка сІВАЗЕ IV можно 
выполнять по-одной в командном режиме или в пакетном 
режиме в виде программ. В состав элементов командного языка 
входят команды, $ЕТ-команды, функции, переменные и массивы. 

Команда записывается в виде строки слов, в которую входит 
глагол - основное слово, определяющее содержание операции, 
выполняемой командой, список выражений и ключевые слова с 
аргументами. Структура командной строки называется синтакси¬ 
сом команды. Многие команды обработки файлов строятся по 
следующей форме: 

< глагол > [<список выражений >] [< границы >] 

[РОК < условие >] [>ѴН НЕ < условие >] 

[ТО РНЕ <имя файла> /ТО РКІЫТЕВ 

/ТО АККАѴ <имя массива > 

/ТО < переменная >] 

[АН [ЫКЕ/ЕХСЕРТ <ша6лон>]] [ІИ <алиас>] 

Квадратные скобки означают использование заключенных в 
них элементов синтаксиса по выбору. В угловых скобках, 
следующих после ключевого слова, записываются его аргументы. 
Косая черта, наклоненная вправо (/), обозначает, что может 
быть записано только одно из разделенных этим знаком 
ключевых слов. Угловые, квадратные скобки и косая черта в 
записи команды для ее выполнения не указываются и служат 
только для пояснения синтаксиса. 

Выражение представляет собой комбинацию имен полей 
файлов БД, переменных, элементов массивов, констант, функций, 
системных переменных и операторов. Данные в полях, перемен¬ 
ных, массивах, функциях и константы могут быть четырех типов 
и обозначаются в синтаксисе команд следующими сокращениями: 
<выр.С> - тип С (символьный), <вь|р.Н> - тип N (числа в 
двоично-десятичном коде), <выр.Р> - тип Р (числа в двоичном 
коде с плавающей запятой), <выр.й> - тип О (даты), <усло- 
вие> - тип 1. (логический). Данные символьного типа должны 
заключаться в разделители, например двойные или одинарные 
кавычки или квадратные скобки. Различие между двумя типами 
чисел определяется способом внутреннего представления и не 
влияет на форму их ввода и вывода. Существуют две основные 
формы ввода-вывода чисел: обычная, в виде десятичных цифр, 
где дробная часть отделяется точкой и в виде мантиссы с 
порядком числа (научная запись чисел). Числа в двоично-деся¬ 
тичном коде не округляются и поэтому их целесообразно 
использовать в финансовых расчетах, где требуется точный 
баланс операций. Форма чисел с плавающей запятой больше 
подходит для научных расчетов, так как позволяет оперировать 
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с очень большими и очень малыми числами, особенно при 
многократных вычислениях. По умолчанию все вводимые числа 
представляются в двоично-десятичном коде. Для перевода в 
форму с плавающей запятой можно использовать функцию 
РЮАТ(). Если поле файла БД определено как тип Р, то числа 
можно вводить в этой форме. Тип числа, возвращаемого 
функциями, зависит от вида функции. Так, функции ЕХР(), 
ЮС(), $окто и все тригонометрические функции возвращают 
числа в форме типа Р. Все другие функции возвращают тип N 
или тот тип, который использовался при вводе данных. Следует 
отметить, что результат совместных операций с числами типа Р 
и N всегда представляется в форме Р. Очень большие и очень 
малые числа типа N всегда выводятся в форме мантиссы с 
порядком, например, 3.655 Е + 09. Данные типа даты занимают 8 
байт. По умолчанию даты вводятся в американском формате 
мм/дд/гг (мм - месяц, дд - день, гг - год). Другой формат, 
например, европейский дд/мм/гг, можно установить командой 
ЗЕТ ОАТЕ или в качестве значения параметра ОАТЕ в СопІід.сІЬ 
файле. При вводе данных типа даты для идентификации они 
должны заключаться в фигурные скобки, например: {23/10/89}. 
Можно вводить дату в виде символьной строки, преобразуя ее 
в форму типа даты специальной функцией: СТОО("23/Ю/89"). 

С датами можно выполнять некоторые арифметическме опера¬ 
ции. Например, в результате вычитания дат получается 
разность - число дней между датами. Это число можно прибав¬ 
лять или вычитать из даты, в результате чего получается новая 
дата. 

Логические данные имеют значения "Истина" и "Ложь", 
которые записываются в виде (.Т.) и (.Р.). При вводе допуска¬ 
ются альтернативные обозначения .1., .V., .у. и .Р., Л., .И., .п. 
Логическое выражение называется также условием. 

Все данные в выражении должны быть одного типа. Если в 
выражении требуется использовать данные разных типов, их надо 
преобразовать в один тип специальными функциями. Выражения 
в списке могут быть различного типа. 

Операторы в выражениях обозначают операции с данными 
и обозначаются специальными символами. В сіВАЗЕ IV использу¬ 
ются четыре типа операторов: математические, операторы 
отношений, логические и строковые. Исходными данными и 
результатом действия математических операторов являются числа. 
В качестве символов математических операторов используются: 


+ 

(сложение 

или 

положительный знак числа) 

- 

(вычитание 

или 

отрицательный знак числа); 

* 

/ 

** или 

(умножение] 
(деление); 
л (возведение 

1; 

в 

степень); 

о 

(для образования групп операторов). 
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Операторы отношений используются с данными любого типа. 
Результатом действия этих операторов являются логические 
значения .Т. и .Р. В качестве операторов отношений^ служат 
символы: 

< (меньше чем); 

> (больше чем); 

= (равно); 

< > или # (не равно); 

< ж (меньше или равно); 

> = (больше или равно); 

$ (сравнение подстрок). 

Последний оператор сравнивает левую и правую строки, 
определяя, содержится ли левая строка в правой. Например, для 
строк А и В выражение А $ В возвращает .Т., если А = В или 
А содержится в В. С помощью операторов отношений формиру¬ 
ются элементарные логические условия, включающие два 
выражения одного типа данных и оператор между ними. 

Для сравнения выражений и элементарных логических 
условий используются логические операторы: 

.АИР. (логическое И); 

.ОК. (логическое ИЛИ); 

.НОТ. (логическое НЕ); 

() (для образования групп логических условий). 

Строковые операторы ( + ) и (-) позволяют сцепить две 
строки данных и образовать одну. При использовании первого 
оператора конечные пробелы обеих строк помещаются в начало, 
а при использовании второго - в конец результирующей строки. 

В сложных выражениях, включающих несколько операторов, 
они выполняются в порядке, определяемом приоритетами 
(правилами предшествования). Операторы отношений и строко¬ 
вые операторы имеют равные приоритеты (один уровень 
предшествования) и выполняются в порядке слева направо. 
Математические операторы имеют разные приоритеты и выполня¬ 
ются в следующем порядке: знаки чисел, возведение в степень, 
умножение и деление, сложение и вычитание. Логические 
операторы выполняются в порядке: .ИОТ., .АИО., .ОК. Если в 
одно выражение входят различные типы операторов, то они 
выполняются в порядке: математические или строковые, операто¬ 
ры отношений, логические операторы. Операторы с равным 
приоритетом выполняются в порядке их записи слева направо. 
Для изменения порядка выполнения операторов образуются 
группы, помещаемые в скобки. Группы могут быть вложенными. 
В этом случае выполнение начинается с самых внутренних групп. 

Если в выражение вводится поле из файла БД не из 
текущей рабочей области, то перед ним нужно указать алиас 
(псевдоним) этого файла БД со стрелкой вправо (->), 
например, КасІгу->Рат (понятие алиаса дается ниже). 
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Границы в приведенном выше общем синтаксисе команды 
указывают те записи файла БД, которые будут доступны при его 
обработку. В качестве ключевых слов границ могут быть: 
КЕСО&О <п> - доступна только одна запись с заданным 

номером; ИЕХТ <п> - доступны все записи, начиная с номера 
п; Ли - доступны все записи файла БД; КЕЗТ - доступны записи, 
начиная с текущей до конца файла. 

Опции РОК и \ѴНІІ.Е определяют условия отбора записей 
для обработки. Эти опции имеют приоритет перед границами 
при определении доступа к записям. Опция РОК определяет 
доступ к обработке начиная с первой записи и до конца 
файла БД, а >УНИЕ - начиная с текущей записи и до тех пор, 
пока условие имеет логическое значение "Истина" (Тгие или .Т.). 

Опция ТО управляет выводом информации, обработанной 
командой. В ряде команд выходной поток можно направить в 
файл на диске, на принтер, в массив или переменную. Перемен¬ 
ная представляет собой хранилище данных любого типа в 
оперативной памяти ПК. Для обращения к переменной ее нужно 
определить - назначить имя и тип. Тип определяется присвоени¬ 
ем переменной значения соответствующего типа. Переменные 
могут входить в синтаксис ряда команд, например, таких как 
АССЕРТ, АУЕКАСЕ, САІ.СШ.АТЕ, СОІІИТ, ІЫРЦТ, РАКАМЕТЕК5, 
РКІУАТЕ, РУВЫС, 5ТОКЕ, 51Ш и ^АІТ. Массив представляет 
собой набор переменных, которые в сІВАЗЕ IV могут быть 
представлены в виде строки (одномерный массив) или таблицы 
(двумерный массив) значений. Каждое значение набора 
переменных называется элементом массива и может входить в 
состав выражения. Опция АП. ПКЕ позволяет отобрать среди 
имен файлов, полей файлов БД и переменных те, которые 
соответствуют заданному шаблону. Шаблон строится по следую¬ 
щему принципу. В него может входить общая часть имен 
нескольких файлов, например, их расширение и знаки замещения 
специфической части ? и *. Первый из них замещает один, а 
второй любое количество символов имени. В шаблоне можно 
использовать только знаки замещения. Например, шаблон *•* 
определяет все имена и типы файлов. Опция АН ЕХСЕРТ 
действует противоположно опции ПКЕ - отбирает имена за 
исключением указанных в шаблоне. Опция ІИ позволяет 
обращаться к файлу БД в другой рабочей области, не выбирая 
ее в качестве текущей. Аргументом этой опции может быть 
алиас рабочей области, ее номер или буква. Напомним, что 
перед тем, как манипулировать с файлом, его надо открыть. В 
сІВАЗЕ IV разрешается одновременно открывать файлы в 10 
рабочих областях. Расположение открытого файла БД отслежива¬ 
ется по алиасу, который представляет собой псевдоним файла БД 
или его имя (используется по умолчанию, если псевдоним не 
задан), номер или букву рабочей области. Псевдоним задается 
опцией АЫА$ команды 0$Е и используется обычно вместо имени 
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файла для ссылки на рабочую область, в которой этот файл 
обрабатывается. Рабочие области имеют номера от 1 до 10, 
которым соответствуют буквы от А до 1. Не следует в качестве 
имени файла использовать одну букву, так как буквы от А до 
\ зарезервированы под имена алиасов, а некоторые из остальных 
используются пакетом СІВА5Е IV в других целях. Ссылка на 
алиас, как и на имя файла, может быть прямой и косвенной. 
Поскольку в одной рабочей области может быть открыт только 
один файл БД, то, по существу, ссылка на рабочую область, 
заданную номером или алиасом, означает ссылку на определен¬ 
ный файл БД. 

При открытии файла не в текущей рабочей области коман¬ 
дой ІІ$Е нужно указывать в опции ІИ ее номер, так как алиас 
задавать нельзя, пока файл не открыт. Имя файла можно 
задавать непосредственно в виде литеральной (буквенно-циф¬ 
ровой) строки до 8 символов или косвенно в виде символьного 
выражения. Отметим, что, если в качестве выражения применяет¬ 
ся переменная, она должна заключаться в круглые скобки, для 
того чтобы отличить ее от имени, заданного в виде литеральной 
строки (символьной строки без кавычек). Например, перед 
открытием файла его имя сначала засылается в переменную: 

Рі 1е = "Касігу" 

ЦЗЕ (Рііе) 

Кроме этого для задания имени файла можно использовать 
функцию макроподстановки &, которая означает, что используется 
не имя переменной, а ее содержимое: 

и$Е &Рі1е 

Если файл находится на диске или в директории, отличном 
от текущего, нужно перед именем файла указывать диск и 
маршрут по директориям, например: 

и$Е С: \0ІЙ1\0АТ1\Рі 1е01 

Открыть файл можно, также используя опцию ? в команде 
ІІ$Е, которая высвечивает список файлов на текущем или другом 
диске. Каждый файл БД открывается в своей рабочей области. 

Особой разновидностью команд являются 5ЕТ-команды, 
устанавливающие параметры среды, в которой выполняются 
обычные команды. Применяются две формы этих команд: 

$ЕТ < параметр > ТО < выражение > и 
$ЕТ < параметр> ОИ/ОРР 

Первая форма устанавливает значение параметра, а вторая 
включает (ОИ) или выключает (ОРР) его действие, т.е. 
устанавливает состояние. Эти команды можно выполнять в 
программах, в командном режиме, можно также занести их в 
специальный файл с именем СопЯд.сіЬ, определяющий параметры 
среды на весь сеанс работы с пакетом СІВА5Е IV. В этот файл 
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$ЕТ-команды записываются без слова $ЕТ по следующей форме: 
<глагол> = <значение>. В качестве значений используются 

слова ОЫ (состояние включено) или ОРР (состояние выключе¬ 
но), а также другие ключевые слова, употребляемые в соответ¬ 
ствующей команде. В файл Сопіід.сІЬ также можно занести 
специальные команды установки параметров среды сІВАЗЕ IV, 
такие как символ приглашения в командный режим, имя 
внешнего текстового редактора, имя драйвера принтера и др. 
Более подробно об этих командах изложено в руководстве по 
сІВАЗЕ IV фирмы АзЬіоп-Таіе. Здесь лишь опишем команду 
РКІЫТЕК. Эта команда позволяет установить четыре различных 
драйвера принтеров и от одного до пяти шрифтов для каждого 
из принтеров. Для установки драйверов используется команда 

РКІЫТЕК <номер принтера> = <драйвер> 

[ИАМЕ < принтер >] 

[РЕѴІСЕ < устройство >] 

где номер принтера - это число из диапазона 1...4, драйвер - 
имя файла драйвера, принтер - тип принтера, задаваемый 
символьной строкой, которая появляется в меню Ргіпі УЦ при 
выборе требуемого принтера, устройство - тип порта, к которому 
присоединен принтер. Например, для установки драйвера 
лазерного принтера НеѵѵІеі-РаскагсІ І_а$егІеі используется команда 

РКІИТЕК 1 = НРІ_А$100.рг2 ИАМЕ "НеѵѵІеП-Раскагсі ЬазеПеГ 
ОЕѴІСЕ СОМ1 

Различные типы шрифтов можно установить командой 

Р&ІИТЕК < номер принтера > РОЫТ < номер шрифта> = 

<начальный код> г <конечный код> 

[ИАМЕ < наименование > ] 

где номер принтера соответствует номеру, назначенному в 
предыдущей команде: номер шрифта - это число из интервала 
назначенное заданному шрифту; начальный и конечный 
коды - это управляющие символы, первый из которых включает, 
а второй выключает заданный шрифт (эти коды специфичны для 
каждого шрифта), наименование представляет собой символьную 
строку для обозначения заданного шрифта, которая появляется 
в меню Ргіпі УЦ. Например, для установки шрифта Котап-8 в 
качестве первого шрифта для принтера І_а$ег.)еі используется 
команда 

РКІЫТЕК 1 РОИТ 1 = {е$с}(81І.{е$с}(#(2) г МАМЕ = "Ротап-8" 

Кроме $ЕТ-команд и специальных команд установки среды 
сІВАЗЕ IV в файле СопІід.сІЬ можно назначить размеры блоков 
оперативной памяти, занимаемой переменными и элементами 
массивов, запрограммировать функциональные клавиши и 
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установить цвет различных областей экрана. Более подробные 
сведения об этих параметрах приводятся при описании соответ¬ 
ствующих команд в разд. 3.2 и 3.7. 

Кроме команд в языке сіВАЗЕ IV используются функции, 
которые позволяют обрабатывать данные (в том числе, выпол¬ 
нять вычисления), а также определять состояния, например, 
находится ли указатель записей в конце файла: ? ЕОР(). После 
имени функции обычно стоят круглые скобки (кроме функции 
макроподстановки «). в которых могут помещаться аргументы. 
Функции нельзя использовать самостоятельно, а только вместе 
с какой-либо командой. Уже упоминавшаяся функция макропод¬ 
становки & применяется к строковым переменным и означает, 
что команда оперирует с содержимым переменной, а не с ее 
именем. Например, в переменную сначала заносится имя поля 
файла БД, а затем это поле выводится на экран: 

5Т0КЕ "Раш" ТО Роіе 

ІЛ5Т &Ро1е 

Последняя команда эквивалентна команде К.І5Т Рат. функция 
макроподстановки позволяет модифицировать действие команды 
программно или с клавиатуры и затем повторно ее выполнять 
в модифицированном виде, не меняя самой записи команды. 
Можно также полностью заменять в переменной целую команду, 
что дает возможность программно или с клавиатуры модифици¬ 
ровать часть или всю программу (т.е. при выполнении програм¬ 
мы модифицировать самое себя): 

Сотпапсіа = [УЗЕ Рііеі] 

&СошапУа 

Сошапсіа = [СЮ5Е Рііеі] 

Следует отметить, что псевдокомпилятор сіВАЗЕ IV при 
компилировании программ оставляет некомпилироваными 
команды, в которых используются функции макроподстановки, и 
возвращается к их компиляции уже в ходе выполнения програм¬ 
мы, когда определено конкретное значение переменной с 
макроподстановкой. Это значительно замедляет процесс выполне¬ 
ния программ. Выше упоминалось, что в командах, включающих 
имена файлов, можно вместо функции макроподстановки 
использовать косвенную ссылку на имя файла в виде переменной 
(заключаемую в скобки), в которую предварительно вводится 
его имя. При таком способе задания переменного имени файла 
команда выполняется значительно быстрее. 

Кроме системных функций в сіВАЗЕ IV можно использовать 
функции, созданные самим пользователем (более подробно см. 
команду РІІНСТІОИ в разд. 3.6). 

Системные переменные в сіВАЗЕ IV служат для управления 
выводом данных на печать и экран, а также позволяют устано¬ 
вить (возвратить) состояние параметров этого вывода, что 
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делает их сходными по своим действиям с $ЕТ-командами и 
функциями. 

Режим ввода и исполнения команд с клавиатуры отмечается 
точкой в левом нижнем углу экрана. Выполнение набранной 
команды осуществляется клавишей Епіег. Командная строка в 
этом режиме может быть длиной до 254 символов. Для набора 
команд, не умещающихся в эту длину, можно использовать 
режим ввода в окно, который устанавливается клавишами 
СігІ-Ноте. В этом случае можно набирать команды длиной до 
1024 символа. Команды и некоторые ключевые слова можно 
записывать не полностью, а первыми четырьмя буквами, 
например, вместо МОРІРУ СОММАЫР писать МОРІ СОММ и 
употреблять как прописные, так и строчные буквы, а также их 
комбинации. Между словами в командной строке допускается 
любое количество пробелов. Режим ввода команд с клавиатуры 
имеет свой буфер, называемый НІ5ТОВУ, в котором сохраняются 
введенные команды. Это позволяет вновь высвечивать на экране 
ранее введенные команды (навигационными клавишами Вверх 
и Вниз), редактировать и выполнять ^и.х повторно. По умолчанию 
буфер позволяет хранить до 20 команд. Его размер можно 
увеличить до 16000 командных строк с помощью команды $ЕТ 
НІ5ТОКѴ. Команды ОІ5РІАѴ/Ы5Т НІ5ТОКѴ позволяют высветить 
на экране хранящиеся в буфере команды. 


3.2. РАЗРАБОТКА БАЗ ДАННЫХ 

Создание файла БД осуществляется командой СКЕАТЕ <имя 
файла > 5ТРІІСТІІРЕ. Этот процесс был подробно описан в гл. 2 
при изложении функций УЦ. Для модификации созданной 
структуры файла используется команда МОРІРУ $ИШСТІЛІЕ. Эта 
команда перед модификацией структуры делает копию файла БД 
с расширением .Ьак и файла Мето полей с расширением .1Ьк. 
После завершения модификации содержимое одноименных полей 
из скопированных файлов вводится в модифицированный файл. 
Следует помнить, что при модификации структуры требуется 
значительный дополнительный объем дискового пространства. Как 
уже упоминалось в гл. 2, в функциях УЦ реализованы не все 
команды языка СІВА5Е IV. В частности, при создании структур 
файлов БД командный язык предоставляет значительно большие 
возможности. Например, можно создать копию структуры файла 
БД (пустой файл БД) с помощью команды СОРУ 5ТКІІСТІІКЕ ТО 
<имя файла > [РІЕІ.05 <список полей >]. При этом можно 
копировать не все поля, а те, которые указаны в списке. 

Пример: 

УЗЕ Ріо 

СОРУ ЗТЛУСТУКЕ ТО Ріоі 
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Команда СОРУ ТО <имя файла > 5ТІШСТІЛІЕ ЕХТЕМЭЕй 

позволяет еще больше расширить возможности по созданию 
структур файлов БД. Данная команда создает файл БД с полями: 
НЕЮ_ЫАМЕ ( имя поля), РІЕЮ _ ТУРЕ ( тип поля), РІЕЮ.ІЕЫ 
(длина поля), РІЕІ.О_ОЕС (число десятичных позиций) и 
РІЕЮ__ЮХ (признак индексирования поля), в которые заносятся 
параметры структуры текущего файла БД. В этом файле можно 
заменить значения полей на новые и затем создать структуру 
файла, соответствующего новым значениям полей, командой 
СКЕАТЕ <имя файла > РВОМ <имя файла структуры БД>. 
Таким способом можно автоматически создавать новые структуры 
файлов с помощью разработанной для этой цели процедуры. В 
этой процедуре может понадобиться определить имя поля по 
его порядковому номеру в структуре файла. Для этого служит 
функция РІЕЮ( свыр.И>[ г <алиас>]), которая возвращает имя 
поля файла БД в соответствии с этим номером в текущей 
рабочей области или заданной алиасом. 

Следует отметить, что файл, созданный командой СОРУ ТО 
<имя файла > $ТК1)СТ1Л1Е ЕХТЕКЮЕО в сІВАЗЕ 111 + , не совмес¬ 
тим с файлом СІВА5Е IV, так как последний имеет дополнитель¬ 
ное поле РІЕІ_0_ЮХ. Это поле используется для создания 
связанного множественного индексного файла. 

Как уже упоминалось, в СІВА5Е IV в отличие от сІВАЗЕ III 
употребляется новый тип индексного файла - множественный 
индексный файл с расширением .тсіх. Этот файл представляет 
собой собранные вместе обычные индексные файлы, используе¬ 
мые в сІВАЗЕ III. Индексные файлы в составе множественного 
индексного файла называются указателями индексов (ТАС). В 
сІВАЗЕ IV создаются два вида множественных индексных 
файлов - связанный и автономный, которые имеют одинаковое 
расширение. Отличие их состоит в том, что связанный множест¬ 
венный индексный файл может создаваться автоматически и его 
указатели являются простыми, т.е. представляют собой поля 
файла БД, которые указаны для индексирования в поле 
РІЕІ.О_ЮХ файла структуры файла БД (при автоматическом 
создании). Этому индексному файлу присваивается имя файла 
БД, и он открывается автоматически вместе с файлом БД. 
Автономный множественный индексный файл или просто 
множественный индексный файл создается командой ІИРЕХ ОИ 
(связанный множественный индексный файл также может 
создаваться этой командой). Указатели индексов в нем могут 
быть не только простыми, состоящими из одного поля, но и 
сложными, состоящими из нескольких полей, включенных в 
индексное выражение, которое можно сформировать из этих 
полей. Файлам такого типа нужно присваивать уникальное имя. 
Можно создать до 10 файлов последнего вида, тогда как 
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связанный множественный индексный файл может быть только 
один. 

Для совместимости в сІВАЗЕ IV используются индексные 
файлы сІВАЗЕ III (типа .псіх), а также предусмотрены команды 
создания этого типа файлов, копирования указателей множествен¬ 
ных индексных файлов в этот тип файла и другие операции, 
связанные с файлами типа .псіх. Для создания индексных файлов 
типа .псіх и .тсіх используется команда 

ІИРЕХ ОЫ < индексное выражение > 

ТО <имя .псіх файла>/ 

ТАС <имя указателя индекса .тсіх файла > 

[ОР <имя .тсіх файла>] [ІЖІСШЕ] [ОЕЗСЕИОІИО] 

Множественный индексный файл создается при использовании 
опции ТАО и может содержать до 47 указателей индексов, 
которые определяются заданными индексными выражениями. 
Если индексное выражение включает несколько типов полей, то 
они должны быть приведены к одному типу. Для этого следует 
использовать специальные функции, например $ткО, зіівзтао, 
СТОРП, ОТОС[), ЭТОЗП, ѴЕАКО, МОИТНО, ОАУ() И ѴАЦ) 
(см. раздел 3.7). Имена указателей индексов записываются так 
же, как и имена обычных переменных: содержат до 10 символов 
(включая буквы, цифры и символы подчеркивания) и должны 
начинаться с буквы. Для того чтобы определить, что в символь¬ 
ной переменной содержится имя, т.е. значение начинается с 
буквы, можно использовать функцию ІЗАІ.РНА( <выр.С> ), кото¬ 
рая возвращает логическое значение .Т., если символьное 
выражение начинается с буквы. 

Если в опции ОР не задано имя .тсіх файла, то создается 
связанный множественный индексный файл. Оглавление файла БД 
содержит метку, указывающую на наличие связанного множест¬ 
венного индексного файла. Для создания индексного файла типа 
.псіх следует использовать опцию ТО < имя. псіх файла>. 

При работе с индексированным файлом БД только один 
индексный файл типа .псіх или указатель множественного 
индексного файла типа .тсіх является управляющим, т.е. 
определяет расположение записей при выводе (напомним, что 
физическое расположение записей при индексировании не 
меняется). Управляющим индексом по умолчанию становится 
вновь созданный индекс. Установка нового управляющего индекса 
выполняется командами ЗЕТ ІИОЕХ или ЗЕТ ОКРЕК. 

Для того чтобы индексные файлы автоматически перестраива¬ 
лись при обновлении, удалении или добавлении записей, нужно, 
чтобы они были открыты. В этом отношении преимуществом 
обладает связанный множественный индексный файл, который 
открывается автоматически вместе с файлом БД. Если изменение 
файла БД выполнялось при закрытых индексных файлах, то 
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перестроение последних в соответствии с новым состоянием 
файла БД можно выполнить командой КЕІИРЕХ. 

Опция ІЖЮІІЕ позволяет включать в индекс только первую 
запись с повторяющимся значением индексного выражения. Более 
подробно описание этой опции приведено в команде 5ЕТ 
ІЖІСШЕ. Опция ОЕЗСЕЫОІИС выстраивает указатели .шсіх файла 
в уменьшающемся порядке (по умолчанию принят увеличиваю¬ 
щийся порядок). 

Пример: 

ЫЗЕ Іакиркі 

INОЕХ ОИ даіе ТА6 Оа*е 0Е$СЕ1№1№ 

и$т 

Индексные файлы и поля (файлы) Мето записываются на 
диск блоками фиксированной длины. Длина блока определяет 
скорость манипуляции этими данными. При увеличении блоков 
имеется тенденция к ускорению обработки их содержимого и 
одновременно замедлению процесса ввода-вывода. При умень¬ 
шении размера блока, наоборот, замедляется обработка содержи¬ 
мого, но в то же время ускоряется ввод-вывод. По умолчанию 
длина блока равна 512 байт. Команда $ЕТ ВІ.ОСК5І2Е ТО 
<выр.Ы> устанавливает размер блоков полей Мето и множест¬ 
венных индексных файлов (.тсіх) в единицах, кратных 512 бейт. 
Увеличение размера блока для больших полей Мето, например 
до определенного размера, ускоряет процесс их обработки. Но 
дальнейшее увеличение размера блока приводит к уменьшению 
коэффициента заполнения блока информацией и, следовательно, 
к увеличению объема файла, что замедляет его обработку. 

Как уже упоминалось для того, чтобы перестроить индексные 
файлы в соответствии с выполненными изменениями файла БД, 
сделанными при закрытых индексных файлах, используется 
команда КЕІЫРЕХ, которая осуществляет переиндексацию всех 
открытых .псіх и .тсіх файлов текущей рабочей области. Статус 
ІЖЮІІЕ остается неизменным, если файлы были созданы с 
установленной командой $ЕТ ІЖЮІІЕ ОМ или опцией ІЖЮІІЕ 
команды ІМРЕХ, независимо от текущей установки команды $ЕТ 
ІЖЮІІЕ. 

Команда 5ЕТ ІІЫІОІІЕ ОМ действует аналогично опции 
ІЖЮІІЕ и устанавливает состояние ІЖЮІІЕ - режим включения 
в индексные файлы (.псіх и .тсіх) только первых записей с 
повторяющимся значением индексного выражения (эта команда 
должна быть выполнена до команды ЖРЕХ). 

Команда 5ЕТ ІЖЮІІЕ ОРР (устанавливается по умолчанию) 
отменяет данный режим. При выполнении команды КЕЖОЕХ 
над индексом, который был создан в состоянии ІЖІСШЕ, он 
сохраняет свой статус ІЖЮУЕ независимо от текущего значения 
параметра $ЕТ ІЖЮІІЕ (ОЫ или ОРР) в ходе переиндексации. 
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Обновление и добавление новых записей в файл с открытым 
индексом не изменяет его статус ІЖЮІІЕ. Это означает, что 
если, например, с помощью команды АРРЕИР добавляется 
запись, значения полей которой, входящих в индексное выраже¬ 
ние, дублируют содержащиеся в индексном файле, то эта запись 
не включается в индексный файл, но добавляется в файл БД. 
Подобным образом, если при обновлении записи формируются 
значения полей, совпадающие с уже существующими, и индекс¬ 
ный файл находится в состоянии ІЖІСШЕ, то эта запись удаляет¬ 
ся из индексного файла. Для того чтобы вернуть индексный 
файл, переведенный в состояние ІЖІСШЕ, в исходное (не 
ІЖІСШЕ) состояние, нужно перестроить индекс с помощью 
команды ІНОЕХ ОИ при состоянии $ЕТ ІЖІСШЕ ОРР. 

Если при обновлении файла, находящегося в состоянии 
ІЖІСШЕ, изменяется запись, и есть скрытые дублирующие записи 
по проиндексированным полям, то эти записи не вводятся в 
индексный файл до тех пор, пока не будет выполнена команда 
КЕШРЕХ. 

Как уже упоминалось, для открытия индексных файлов 
используется команда 

$ЕТ ІЫРЕХ ТО [/?<список имен файлов> 

[ОІЮЕК [ТА©] <имя .псіх файла>/ 

<имя указателя индекса > 

[ОР <имя .тсіх файла >]]] 

Эта команда открывает индексные файлы типа .псіх и .тсіх 
и может задавать для активного файла БД управляющий 
индексный файл или указатель индекса множественного индекс¬ 
ного файла. Если не указано расширение индексного файла, то 
сначала выполняется попытка открыть .тсіх файл, а затем .псіх 
файл. 

При выполнении команды $ЕТ ІЫРЕХ ТО перед открытием 
индексных файлов закрываются все открытые индексные файлы 
в текущей рабочей области, кроме связанного файла .тсіх, затем 
открываются индексные файлы, указанные в списке имен файлов. 
При этом указатель записи файла БД устанавливается на первую 
запись в соответствии с главным (управляющим) индексом. 

Команда $ЕТ ІИОЕХ ТО без опций закрывает все открытые 
файлы .псіх в текущей рабочей области, а файлы .тсіх оставляет 
открытыми. Эти же действия выполняет команда СІ.05Е ІЫОЕХ. 

Индексный файл, указанный в опции ОІШЕК, устанавливается 
как главный или управляющий индекс. Этот индекс может быть 
файлом типа .псіх или указателем множественного индексного 
файла типа .тсіх. В последнем случае следует задать имя файла 
в опции ОР (для связанного файла .тсіх это не требуется). Если 
открыт только один индексный файл, то он автоматически будет 
главным. В этом случае опция ОКОЕК не требуется. При 
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выполнении команды 5ЕТ ІНОЕХ ТО указатель файла БД 
устанавливается на первую запись в соответствии с главным 
индексом. 

При восстановлении естественного порядка обработки файла 
БД командами $ЕТ ОКОЕК ТО 0 или $ЕТ ОКОЕК ТО без опций, 
все индексы продолжают обновляться. Если естественный порядок 
обработки файла БД восстанавливается командой $ЕТ ІИРЕХ ТО 
без опций, 4 то только один связанный файл .тсіх будет по 
прежнему обновляться. Поэтому при восстановлении индексных 
файлов командой КЕІЫРЕХ можно открыть все индексные файлы, 
кроме связанного файла .тсіх. 

V При выполнении команды АРРЕЫР с индексированным 
файлом БД новые записи добавляются в физический конец этого 
файла. После завершения ввода данных в новую запись индекс¬ 
ное выражение этой записи включается в главный индекс и 
запись становится доступной в соответствии с порядком, опреде¬ 
ленным этим индексом. При этом обновляются все индексы, 
включая и все указатели внутри открытого файла .тсіх. Команда 
ІЫ5ЕКТ для индексированного файла БД выполянется аналогично 
команде АРРЕЫР. Одновременно могут быть открыты все 
указатели индексов одного файла .тсіх (47) и до 10 .псіх и 
связанных файлов .тсіх. Если открыт файл .тсіх, то все указатели 
в нем также открываются. 

Примеры: 

ІІЗЕ Ріо 

ЗЕТ ІИОЕХ ТО Раш && Открывает индексный файл Раш. псіх 

ЗЕТ ІИОЕХ ТО Ріо 0К0ЕК Раш && Открывает связанный .тсіх файл и 

* устанавливает в качестве 

* главного указатель Раш 

Используя команду 5ЕТ ОКРЕП, можно переключить уста¬ 
новку главного индекса, не закрывая файлы .псіх и .тсіх: 

$ЕТ ОКРЕП ТО 

5ЕТ ОКРЕП ТО [<выр.Ы>] 

5ЕТ ОКРЕП ТО [ТАС] <имя файла>/ 

<указатель .тсіх файла> 

[ОР <имя .тсіх файла>] 

Данная команда позволяет установить любой открытый файл 
.псіх или указатель .тсіх файла в качестве главного индекса или 
отменить управление файла БД всеми открытыми индексами, не 
закрывая их. Это дает возможность сэкономить время, затрачива¬ 
емое на открытие и закрытие индексных файлов, если требуется 
переназначить главный индексный файл, поскольку такие команды 
не закрывают и не открывают индексные файлы и не перемеща¬ 
ют указатель записей. Первая форма команды $ЕТ ОКРЕП ТО 
без опций отменяет индексный режим обработки, т.е. восстанав- 
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ливает обработку записей файла БД в соответствии с их 
физическим расположением и закрывает все индексные файлы. 

Для установки в качестве главного только файла .псіх 
используется вторая форма команды ЗЕТ ОКОЕК ТО <выр.И> 
(при этом файлы .тсіх должны быть закрыты). Числовое 
выражение содержит числа от 0 до 10, соответствующие номеру 
открытого файла .псіх, в списке, установленном командами ЗЕТ 
ІИЭЕХ ТО или ІІ5Е. Эта команда обеспечивает использование 
индексных файлов типа .псіх, созданных в сІВАЗЕ III +, хотя их 
можно также создавать и в сІВАЗЕ IV. 

Если одновременно открыты файлы .тсіх и .псіх, то для 
установки главного индекса используется третья форма команды. 
В этом случае для задания имен индексных файлов в отличие от 
второй формы нужно указывать не их порядковые номера, а 
имена, как непосредственно, так и косвенно, в виде содержимого 
переменных. При установке в качестве главного указателя 
множественного индексного файла, не являющегося связанным, 
следует задать в опции ОР имя этого файла. Все открытые 
индексные файлы обновляются, если выполняются изменения 
значений индексированных полей, добавление или удаление 
записей. 

Команда ЗЕТ ОМ)ЕК ТО 0 отменяет главный индекс, но 
оставляет индексные файлы типа .псіх открытым для обновления 
при изменении файла БД. Для того чтобы определить текущий 
главный индекс, используется функция ОІН)ЕК([<алиас>]), 
которая возвращает имя управляющего файла .псіх или имя 
управляющего указателя индекса файла .тсіх (прописными 
буквами без расширения). Если алиас не указан, то предполагает¬ 
ся текущая рабочая область. Команды, не использующие 
индексные файлы, например ЬОСАТЕ, действуют быстрее, если 
все индексы закрыты. В ряде случаев возникает необходимость 
копирования указателей множественного индексного файла типа 
.тсіх в индексные файлы типа .псіх, например, в целях использо¬ 
вания их в пакете сІВАЗЕ III. Для этого служит команда 

СОРУ ТАС <имя указателя индекса .тсіх файла > 

[ОР имя .тсіх файла] ТО <имя .псіх файла > 

которая создает новый индексный файл типа .псіх посредством 
копирования указателя файла .тсіх. При копировании файл БД 
должен быть активным, так как команда создает файл .псіх из 
выражения, содержащегося в указателе файла .тсіх, который 
должен быть открытым. Открывается же он только после 
открытия связанного с ним файла БД. Одна операция копирует 
только один указатель. 

Пример: 

ІІЗЕ Зкіасі 

СОРУ ТА6 Ое'Ьпотег ТО Иагѵап іе . псіх 
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ЗЕТ 1№ЕХ ТО Иагѵапіе 

0І5РІ.АѴ ЗТАТОЗ 

Для уничтожения ненужных указателей в множественном 
индексном файле используется команда 

РЕІ.ЕТЕ ТЛС <имя указателя 1> 

[ОР <имя .тсіх файла >]/ 

<имя .псіх файла 1> [ г <имя указателя 2> 

[ОР <имя .тсіх файла >]/ 

<имя .псіх файла 2>...] 

Удаление указателя индекса означает удаление его из 
индексного множественного файла и освобождение занимаемой 
памяти. Перед выполнением команды РЕ1.ЕТЕ ТАС множествен¬ 
ный индексный файл должен быть открытым, а удаляемый 
указатель индекса не должен быть управляющим. Если удаляются 
все указатели индексов, то одновременно удаляется и весь файл 
.тсіх. При удалении связанного файла .тсіх посредством удаления 
всех его указателей в оглавлении файла БД метка о наличии 
связанного файла .тсіх также удаляется. Если каталог открыт, то 
в нем отражаются соответствующие изменения. 

Опция ОР позволяет задать имя файла .тсіх, который 
содержит удаляемый указатель индекса (для связанного файла 
.тсіх эта опция не задается). Например, если два открытых файла 
.тсіх содержат указатели индекса с одним именем, то для 
удаления одного из них требуется указать имя файла .тсіх. 

Вместо удаления указателей файлов .тсіх данная команда 
позволяет закрыть индексные файлы типа .псіх. В этом случае 
используется альтернативная опция (в синтаксисе команды 
отделена косой чертой), в которой задается имя файла .псіх. 
Этот альтернативный вариант команды полезен с целью экономии 
времени в тех случаях, когда требуется закрыть только несколь¬ 
ко файлов .псіх, а остальные оставить открытыми. Такой резуль¬ 
тат можно также получить с помощью команды 5ЕТ ІИРЕХ. 
Однако при применении последней команды все открытые файлы 
сначала закрываются, а затем вновь открываются заданные, на 
что тратится больше времени. 

Пример: 

0Е1.ЕТЕ ТА6 Рат ОР Ріо 

При переходе с пакета СІВА5Е III на СІВА5Е IV может 
возникнуть потребность в переводе индексных файлов типа .псіх 
в файлы типа .тсіх. Для этого служит команда 

СОРУ 1И0ЕХЕ5 <список .псіх файлов> 

[ТО <имя .тсіх файла>] 

которая копирует список файлов .псіх в указатели файлов в 
одном множественном индексном файле. Если не указано имя 
файла .тсіх, то указатели записываются в связанный файл .тсіх. 
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Если же этот файл не существует, то он создается (по опреде¬ 
лению ему присваивается имя активного файла БД). Одной 
командой можно копировать до 47 индексных файлов типа .псіх. 

При работе в среде ЛВС перед выполнением команд 
КЕІЫРЕХ, СОРУ ТАС, 0Е1.ЕТЕ ТАС и СОРУ ІЫ0ЕХЕ5 файл БД 
должен быть установлен в исключительное распоряжение одного 
пользователя (см. разд. 3.8). 

Пример: 

У$Е Ріо 1№ЕХ Раш 

СОРУ 1№ЕХ Рат 

При работе с индексированными файлами БД может возник¬ 
нуть надобность вывести информацию, записанную в созданные 
ранее индексные файлы, например о составе индексного 
выражения, имени файлов .тсіх и .псіх, указателях индексов в 
файле типа .тсіх, текущем управляющем индексе и т.д. Для 
этого служат специальные функции. Напомним, что функции 
можно использовать только в составе команд. В командном 
режиме для вывода информации на экран часто используется 
функция ? (см. разд. 3.4). Функция КЕУ([<имя .тсіх файла> г ] 
<выр.И> [ г <алиас>]) возвращает индексное выражение 
файлов типов .тсіх и .псіх, которое задано числовым выражени¬ 
ем, определяющим порядковый номер файла в текущей рабочей 
области. Для файла .тсіх нужно задать его имя, а выражение 
будет определять порядковый номер указателя индекса. Если 
требуется вывести информацию о файле, находящемся в другой 
рабочей области, то указывается ее алиас. Для вывода 
имен файлов типа .тсіх используется функция МОХ(<выр.И> 
[ г <алиас>]), которая возвращает имя файла .тсіх, указанного 
порядковым номером в списке индексных файлов, установленном 
командой 5ЕТ ІИРЕХ ТО в текущей рабочей области или 
заданной алиасом. При отсутствии .тсіх файлов возвращается 
нулевая строка. Функция ИОХ( < выр.Ы > [, < алиас > ]) возвращает 
имя файла .псіх, соответствующее заданному числовому выраже¬ 
нию, которое представляет собой номер позиции в списке 
индексных файлов текущей рабочей области или заданной 
алиасом. Если командами $ЕТ ІЫРЕХ ТО или ІІ5Е 1ИРЕХ открыто 
N файлов .псіх, то число, полученное из заданного выражения в 
диапазоне от 1 до Ы, будет возвращать имена этих .псіх файлов, 
а числа свыше будут соответствовать указателям файлов .тсіх и 
каталогизированным файлам .псіх (при открытом каталоге). 

Функция ТАС([<имя .тсіх файла> г ] <выр.Ы> [,<алиас>]) 
возвращает имя указателя индекса в заданном индексном 
множественном файле .тсіх в соответствии с указанным числовым 
выражением. Если имя файла .тсіх не указывается, то возвраща¬ 
ется имя любого открытого индексного файла из списка файлов 
в текущей (заданной алиасом) рабочей области в соответствии 
с числовым выражением. При отсутствии открытых индексов 
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возвращается нулевая строка. Для вывода имени текущего 
главного индекса - индексного файла типа .псіх или указателя 
индекса в файле типа .тсіх - в текущей или заданной алиасом 
рабочей области используется функция ОІЮЕК([<алиас>]). 

Возвращаемые функциями сІВАЗЕ IV имена файлов содержат 
полный маршрут, тогда как эти же функции в сІВАЗЕ 111 + 
возвращают только имя диска и имя файла. 

Команда $ЕТ РШ.І.РАТН ОРР (устанавливается по умолча¬ 
нию) подавляет (ОИ не подавляет) в возвращаемом вместе с 
именем файла маршруте имена директориев, что обеспечивает 
совместимость с сІВАЗЕ 111+ программ, написанных в сІВАЗЕ IV 
и содержащих функции МОХ(), N0X0 и ОЩ). 

Перед выполнением каких-либо операций с ранее созданным 
файлом его надо открыть. Как уже говорилось, для обеспечения 
обработки файла БД в оперативной памяти выделяется специаль¬ 
ный участок - рабочая область. В каждой рабочей области можно 
открыть один файл БД. Рабочая область 10 зарезервирована для 
каталога. Если каталог открыт, то в этой области открывать файл 
БД нельзя. Если в рабочей области 10 открыт файл БД, а затем 
открывается каталог, то 4эайл БД автоматически закрывается. При 
открытии файла БД в области, уже содержащей открытый файл, 
последний закрывается. В рабочей области вместе с файлом БД 
также открываются и связанные с ним файлы других типов, 
например, индексный файл, файл запроса, экранной формы и др. 
При входе в сІВАЗЕ IV автоматически активизируется рабочая 
область 1. Выбор рабочей области осуществляется командой 

5ЕІ.ЕСТ <имя рабочей области/алиао 

Эта команда активизирует рабочую область для открытия нового 
файла БД или для работы с уже открытым в этой области 
файлом БД. 

Команда 5ЕІ.ЕСТ также используется для переходов между 
рабочими областями. Файл БД, открытый в выбранной рабочей 
области, становится активным. Как уже упоминалось, рабочую 
область можно выбрать, задав алиас (псевдоним) имени файла, 
открытого в этой рабочей области. Если при открытии файла не 
задан алкас, то имя файла (без расширения) по умолчанию 
принимается в качестве алиаса. 

При выборе рабочих областей или алиасов можно прямо 
задавать не только их имена, но и переменные, содержащие эти 
имена. Такой способ задания особенно полезен при применении 
в прикладных программах. В этом случае для выбора различных 
рабочих областей можно использовать одну команду, в которой 
изменяется значение переменной. Тогда перед переменной 
нужно ставить функцию &, которая означает, что выбирается не 
имя переменной, а ее значение. Например, если алиас содержит¬ 
ся в символьной переменной, то следует указать: 
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5ЕІ.ЕСТ &< переменная > 

Обычно команды выводят или изменяют значения полей 
активного файла БД. Тем не менее можно задать поля из других 
открытых рабочих областей, содержащих связанные файлы, 
используя следующий синтаксис: <алиас> -> <имя поля>. 
Если предварительно установлены команды $ЕТ РІЕЮ5 ТО и $ЕТ 
РІЕЮ5 ОИ, то будут доступны поля из файлов в других 
открытых рабочих областях, определенные в списке первой из 
этих команд. 

В каждой рабочей области поддерживается свой указатель 
записи. Переходы между рабочими областями не изменяют 
положения указателей записи. Команды, изменяющие позицию 
указателя записи, действуют только для активного файла БД, 
если не установлена связь файлов с помощью команды $ЕТ 
кЕишои то или не был открыт файл выборки. Напомним, что 
выборкой называется файл БД, получаемый в результате отбора 
данных из нескольких файлов. При этом исходные файлы могут 
быть вообще не связаны или же связаны логически с помощью 
команды ЗЕТ КЕЬАТЮН 

Примеры: 

5Е1.ЕСТ 1 && В области 1 открывается файл Ріо с алиасом Матез 

УЗЕ Ріо ЛИАЗ Иатез 
ЗЕЕЕСТ 3 

ЕІЗЕ Ріпапз && В рабочей области 3 открывается файл Ріпапз 
5ЕІ.ЕСТ Иашез && Рабочая область выбирается по алиасу 
5ЕІ.ЕСТ А && Выбирается рабочая область 1 

Для того чтобы определить алиас рабочей области, использу¬ 
ется функция АЫА$([<выр.Ы>]), которая возвращает алиас 
рабочей области, указанной в числовом выражении. Если номер 
рабочей область не указан, то подразумевается текущая. 
Установить номер высшей неиспользованной рабочей области 
можно с помощью функции $Е1.ЕСТ(). 

Пример: 

МНІе = "Ріо" 

УЗЕ (МРПе) ІИ ЗЕЬЕСТО && Открывает файл БД Ріо в высшей 
* неиспользованной рабочей области 

Для открытия файла БД используется команда 

ІІЗЕ [<имя файла БД>/?] [ІИ <номер рабочей области>] 
[ІИРЕХ ссписок .псіх и .тсіх файлов>] 

[ОМ)ЕК [ТАС] <имя .псіх файла>/ 

< указатель .тсіх файла > 

[ОР <имя .тсіх файла >]] 

[АЫ АЗ < алиас >] [ЕХСШ5ІѴЕ] [ИОУРОАТЕ] 

которая открывает существующий файл БД и связанные с ним 
файлы .тсіх и .псіх в текущей рабочей области. 
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Для открытия в другой рабочей области требуется задать 
опцию ІЫ. Если файл БД содержит поля Мето, автоматически 
открывается соответствующий файл .сІЬі. Одновременно может 
быть открыто до 94 файлов различных типов, но только 9 из них 
могут быть файлами БД, каждый в своей рабочей области. 
Остальные файлы - это связанные с файлами БД файлы 
индексов, экранных форм, отчетов и т.д., которые открываются 
в одной рабочей области со своим файлом БД. Напомним, что 
10-я рабочая область отводится под файл каталога. 

Команда ІІ5Е без параметров закрывает активный файл БД 
и связанные с ним индексы в текущей рабочей области. Команда 
Ц$Е ІИ закрывает файлы в указанной рабочей области. Если не 
указывается расширение файла, то предполагается, что это файл 
БД (имеет расширение .СІЫ), а если не указывается расширение 
индексных файлов, то для них предполагаются расширения .теіх 
или .псіх. При этом сначала осуществляется попытка открыть 
файл .тсіх. При отсутствии файла .тсіх предпринимается попытка 
открыть файл .псіх. После того как открыт файл БД, можно 
открывать и закрывать индексные файлы с помощью команды 
$ЕТ ШйЕХ и закрывать командами СЮ5Е ШЭЕХ и РЕ1.ЕТЕ ТАС. 
Если имя файла БД еще не записано в каталоге и установлена 
команда $ЕТ САТАЮС ОЫ , то оно заносится в каталог. 

Команда ІІ$Е ? высвечивает список файлов БД в каталоге, 
если он открыт, или список всех файлов БД в текущем директо¬ 
рии при закрытом каталоге. Опция АІ.ІА5 назначает алиас файла 
БД, который в дальнейшем может использоваться для ссылки на 
него. Напомним, что если алиас не задан, то по умолчанию он 
совпадает с именем файла БД. 

Опция ЕХСШ5ІѴЕ устанавливает файл БД в исключительное 
распоряжение одного пользователя при работе в среде ЛВС. 
Этот файл не может использоваться другими пользователями, 
пока не будет закрыт командами С1.ЕАК АН., СЮ5Е или ІІ5Е. В 
однопользовательском режиме все файлы открываются со 
статусом ЕХСШ5ІѴЕ. 

Опция ИОІІРОАТЕ защищает открытый файл БД от всякого 
изменения (обновления, добавления или удаления записей), т.е. 
фиксирует режим только чтения. 

Для установки управляющего индекса используется опция 
О&ОЕК. Если в списке индексов указан только один индексный 
файл, то эта опция не требуется. При использовании в качестве 
управляющего указателя не связанного файла .тсіх требуется в 
опции ОР задать его имя. После открытия файла БД указатель 
записи устанавливается на первую запись в соответствии с 
заданным управляющим индексом, который затем определяет 
перемещение указателя записи при работе с файлом. Если 
открывается файл БД, не имеющий индексов, указатель устанав¬ 
ливается на физически первую запись в файле. 
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В гл. 2 подробно описана система каталогизации файлов в 
пакете сІВАЗЕ IV. Здесь лишь поясним команды для работы с 
каталогами. Для создания или открытия существующего каталога 
используется команда 

ЗЕТ САТАЮО ТО [<имя файла каталога >]/? 

Выполнение этой команды начинается с поиска заданного 
файла каталога в текущем директории и в директории, в 
котором размещается сІВАЗЕ IV. Если файл каталога найден, то 
он открывается. В противном случае создается новый файл 
каталога (с расширением .саі). Если создаваемый каталог 
первый, то предварительно формируется главный каталог 
Саіаіод.саі. Этот каталог автоматически помещается в директорий, 
в котором находится сІВАЗЕ IV, и содержит информацию о 
других каталогах. Его можно удалить из директория сІВАЗЕ IV 
или переместить в другой директорий. После удаления из 
директория сІВАЗЕ IV главный каталог автоматически появляется 
в текущем директории. Таким образом, на каждом диске или в 
каждом директории можно создать свой главный каталог. 

Команда ЗЕТ САТАЮО ТО ? высвечивает список каталогов, 
находящихся в главном каталоге вместе с их описаниями, 
которые можно ввести при создании каталога, если установлена 
команда ЗЕТ ТІТІ.Е ОЫ. В этом случае при создании нового 
каталога высвечивается подсказка для ввода описания каталога. 
Если установлена команда ЗЕТ ТІТЬЕ ОРР, то описание каталога 
после его создания можно ввести непосредственно в соответству¬ 
ющее поле файла главного каталога, открытого в любой рабочей 
области, например с помощью команд ЕЭІТ или КЕРІ.АСЕ. 

Кроме этого способа можно ввести описание каталога через 
меню УЦ, описанное в гл. 2. Отметим, что для открытия файла 
каталога в отведенной для него рабочей области 10 используется 
команда ЗЕТ САТАЮО ТО. Если каталог открыт и установлена 
команда ЗЕТ САТАЮО ОН, то все новые файлы (файлы БД, 
связанные с ними индексные файлы, а также запросы, отчеты, 
марки и т.д.), создаваемые командами 


СОРУ ЗТРУСТШЕ 
СОРУ ЗТРІІСТШЕ 
СРЕАТЕ 
СРЕАТЕ ЕРОМ 
СРЕАТЕ/МОйІРУ ЬАВЕЬ 
СРЕАТЕ/МОЭІРУ ОІІЕРУ 
СРЕАТЕ/МОйІРУ РЕРОРТ 
СРЕАТЕ/МОЭІРУ 5СРЕЕІЧ 
СРЕАТЕ/МОРІРУ ѴІЕѴѴ 


ІМРОРТ РРОМ 
ЕХТЕЫЭЕй ІЫЭЕХ 
ЮІЫ 

5ЕТ РИТЕР ТО РНЕ 

ЗЕТ РОРМАТ 

ЗЕТ ѴІЕѴѴ 

ЗОРТ 

ТОТАІ_ 

УЗЕ 


будут в него заносится. По умолчанию установлено состояние 
ЗЕТ САТАІ.ОО ОРР, которое не позволяет каталогизировать 
файлы, но при выборе каталога командой ЗЕТ САТАЮС ТО 
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автоматически устанавливается состояние $ЕТ САТАІ.ОС ОИ. Если 
кроме $ЕТ САТАІ.ОС ОИ установлено еще состояние 5ЕТ ТІТІ.Е 
ОИ, то при создании нового файла указанными выше командами 
высвечивается приглашение для ввода в каталог его описания. 
При открытии каталога выполняется сверка его содержимого с 
перечнем файлов на диске. Если ранее было выполнено 
удаление файлов при состоянии $ЕТ САТАЮС ОРР, то их имена 
удаляются из каталога. 

Закрытие каталога выполняется командой 5ЕТ САТАЮС ТО 
без имени файла. Если требуется только прекратить добавление 
файлов в открытый каталог, следует использовать команду $ЕТ 
САТАЮС ОРР. Возобновление ввода файлов в каталог осущест¬ 
вляется командой $ЕТ САТАЮС ОИ. 

Команда $ЕТ САТАІ.ОС ОРР в отличие от команды $ЕТ 
САТАЮС ТО оставляет каталог открытым и позволяет использо¬ 
вать опцию запроса к каталогу ? в других командах СІВА5Е IV. 
Например, если установлено состояние $ЕТ САТАІ.ОС ОРР, то 
команда МОРІЕѴ КЕРОКТ? высвечивает список имен файлов 
отчета из открытого каталога. В список будут включены все 
файлы, связанные с активным файлом БД. 

Как уже упоминалось, в состоянии $ЕТ САТАІ.ОС ОРР файлы 
не заносятся в каталог. Например, созданный в этом состоянии 
индексный файл не помещается в каталог. Если позже устанавли¬ 
вается состояние 5ЕТ САТАЮС СЖ и задается обращение к 
этому индексному файлу, то в этом случае высвечивается 
сообщение: Рііе поі саіаіодесі, зіпсе 5ЕТ САТАЮС ѵѵаз ОР ѵѵЬеп 
♦Не асііѵе сіаіаЬазе Іііе ѵѵаз ІІЗЕсІ (файл не каталогизирован, так 
как было установлено состояние $ЕТ САТАЮС ОРР при работе 
с файлом БД). 

Файлы каталогов имеют одинаковую структуру (табл. 3.1). 
В поле РіІе_пате записывается имя файла, включая его 
расширение, а в поле АІіаз (заполняется только для файлов БД) 
его алиас. 


Таблица 3.1 Структура файлов каталогов 


Пеісі 

Пеісі Иате 

Туре 

ѴІсЙЬ 

йес 

(номео 

поля) 

(имя поля) 

(тип) 

(ширина) 

(число 

десятичных 

позиций) 

1 

Ра-Ып 

СИагасІег 

2 


2 

Рі1е паше 

СИагасІег 

12 


3 

А1 іаз 

СИагасІег 

8 


4 

Туре 

СЬагасІег 

3 


5 

ТШе 

СЬагасІег 

80 


6 

Сосіе 

Иишегіс 

3 


7 

Тад 

СИагасѣег 

4 


**Всего** 


181 
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Все поля файла каталога, за исключением Тіііе и Тад, 
заполняются системой автоматически при включении нового 
файла в каталог. Поле с именем РаіН содержит маршрут по 
директориям для поиска файла, если он задан при создании 
файла. Если алиас не задан, то в качестве него используется имя 
файла БД. В поле Туре находится расширение имени файла, 
принятое по умолчанию. Если при создании файла ему присвое¬ 
но другое расширение, то оно помещается вместе с именем 
файла в поле РіІе_пате. Поле ТіТІе содержит словесное 
описание файла (до 80 символов), введенное при установленном 
состоянии $ЕТ ТІТІ.Е ОК Изменение описания файла в каталоге 
осуществляется так же, как и описание каталога в главном 
каталоге, например с помощью команды ЕОІТ. 

Пример: 

ІІ5Е <имя каталога». САТ 

ЕОІТ 

Если каталог открыт, то можно просто выбрать рабочую 
область 10. 

Пример: 

$ЕІ_ЕСТ 10 

ЕОІТ 

В поле Сосіе помещается номер, который присваивается 
каждому открытому файлу БД. Программным файлам присваива¬ 
ется 0. Файлу БД присваивается номер при его создании. 
Каждому новому файлу БД присваивается следующий номер. 
Связанным с файлом БД файлам (индексам, экранным формам, 
запросам, отчетам, маркам и т.д.) присваивается тот же номер, 
что и файлу БД. Это поле используется для того, чтобы можно 
было выбрать все файлы различных типов, связанные с одним 
файлом БД. 

Иногда возникает потребность определить имя открытого 
файла БД в рабочей области. Этим целям служит функция 
йВР( <алиас>), которая возвращает имя файла БД, открытого 
в рабочей области, заданной алиасом. 

Для проверки существования указанного файла используется 
функция РІІ.Е(<выр.С >), которая возвращает логическое 
значение .Т., если файл существует. Кроме того, часто применя¬ 
ется функция ШРОАТЕ([<алиас>]), возвращающая дату 
последнего обновления указанного файла БД. 

После того как создана структура файла БД, можно вводить 
данные. Как уже отмечалось в гл. 2, существуют две стандарт¬ 
ные экранные формы ввода (и вывода) информации в файлы 
БД: Вгож$е и ЕсШ. Первая форма вызывается командой 

ВКО№Е [ЫОІЫІТ] [ЫОРОИОѴ/] [ИОАРРЕИй] [ИОМЕИУ] 
[ЫОЕОІТ] [ЫООЕІ.ЕТЕ] [ЫОС1.ЕАК] [СОМРРЕ55] 
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[РОВМАТ] [ЮСК <выр.И>] [\ѴЮТН <выр.И>] 
[РВЕЕ2Е <имя поля>] [Ѵ^ІИОО>Ѵ <имя окна>] 
[РІЕЮ5 <имя поля 1> [/К] [/<ширина колонки>] 
/<вычисл. имя поля 1> = < выражение 1> 
[ г <имя поля 2> [/К] [/< ширина колонки >] 
/<вычисл. имя поля 2> = < выражение 2 >]...] 

Эта команда имеет собственное меню, которое активизиру¬ 
ется клавишей РІО и предназначено для ввода, добавления и 
обновления записей в файлы БД. В дальнейшем при описании 
данной команды под файлом БД будет также подразумеваться 
и выборка. Напомним, что в форме Вгож$е записи файла БД 
выводятся на экран в табличной форме. 

В команде имеется ряд опций, позволяющих устанавливать 
различные режимы ее использования. В число этих опций входит 
группа опций, позволяющая назначить режимы работы с полями, 
и группа опций по размещению полей на экране. В состав 
первой группы входят следующие опции: ИОЕРІТ, позволяющая 
установить режим только чтения для всех полей, ЫОАРРЕЫО, не 
разрешающая добавлять новые записи, и ЫООЕ1.ЕТЕ, не разреша¬ 
ющая помечать записи для удаления. Опция РВЕЕ2Е назначает 
для обновления только одно указанное поле. Другие поля 
высвечиваются, но остаются недоступными для редактирования. 
Если для указанного в опции РВЕЕ2Е поля командой РВОТЕСТ 
открыто только чтение (см. разд. 2.8 и 3.8), то обновление не 
разрешается. Опция РВЕЕ2Е без имени поля отменяет ранее 
назначенную установку. 

Поля высвечиваются в том порядке, который определен 
структурой файла БД или указан в команде опцией РІЕК.Р5, 
входящей в состав второй группы. Эта опция позволяет выбрать 
поле и определить порядок его расположения в таблице Вгоѵѵ$е. 
Установленные командой РВОТЕСТ привилегии перекрывают 
опции команды ВВОѴ7$Е. Если доступ к полю закрыт командой 
РВОТЕСТ, то это поле не высвечивается. Опция РІЕЮ5 также 
позволяет устанавливать для выбранного поля режим только 
чтения, а также создавать высвечиваемое вычисляемое поле по 
форме, приведенной в синтаксисе опции. Имя этого поля 
становится заголовком колонки таблицы Вготе, в которой 
высвечивается значение вычисляемого поля. Длина этого поля 
определяется после вычисления выражения для первой записи. 

Опция /В устанавливает поле в режим только чтения. Если 
этот режим также назначен командой РВОТЕСТ, то, как указано 
выше, команда имеет приоритет над данной опцией. Вычисляе¬ 
мые поля всегда устанавливаются в режим только чтения. Для 
определения ширины колонки (в которой высвечивается поле), 
отличной от установленной по умолчанию, используется опция 
< ширина колонки >, в которой задается число, определяющее 
новый размер колонки (перед ним ставится знак /). Диапазон 
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составляет от 4 до 100 для символьных полей и от 8 до 100 для 
числовых полей и полей типа даты. Для логических и полей 
Мето данная опция не действует. Эта опция также игнорируется, 
если заданное число больше назначенного опцией ѴПРТН или 
меньше ширины поля числовых полей и полей даты, определен¬ 
ных в структуре файла БД. Опция \^ЮТН устанавливает верхний 
предел ширины колонки для всех полей в таблице ВКО>У§Е. Эта 
ширина перекрывает ширину поля, назначенную при создании 
файла БД. Если опции >ѴЮТН и < ширина колонки > используют¬ 
ся одновременно, то принимается наименьшее значение. Данная 
опция, как и предыдущая, не применяется для полей типа Мето 
и логических полей. Значения числовых полей и полей даты не 
будут высвечиваться, если значение опции >ѴЮТН меньше 
ширины этих полей, назначенных при определении структуры 
файла БД. Опция РОКМАТ позволяет разместить поля в таблице 
ВКО>У$Е в очередности, определенной экранной формой, которая 
установлена командой 5ЕТ РОКМАТ ТО и использовать при 
работе с полями все опции команд @...©ЕТ этой экранной 
формы, кроме позиционирования полей (см. разд. 3.4.). Это 
дает возможность подключать к команде ВКОѴ/5Е такие 
возможности, как проверку вводимых данных на соответствие их 
допустимому диапазону, высвечивание сообщения внизу экрана 
при установке курсора на поле, ввод альтернативных значений 
поля и т.д. 

Для того чтобы зафиксировать поля при движении курсора, 
используется опция І.ОСК. В ней задается количество смежных 
полей в левой части экрана, которые будут оставаться на экране 
при движениии курсора вправо по полям таблицы Вгожзе, 
осуществляемом клавишами ТаЬ, $ЫЙ-ТаЬ, РЗ или Р4. Для отмены 
фиксации полей задается опция ЮСК без числового значения 
или с выражением, равным нулю. Опция \ѴІЫОО>Ѵ позволяет 
активизировать окно, которое затем определяет на экране 
область, используемую для высвечивания таблицы Вгож$е. При 
выходе из команды ВКОѴѴ5Е окно автоматически убирается, если 
не задана опция ЫОСІЕАК. Опция НОМЕЫЦ удаляет меню 
команды, а ЫОСІ.ЕАК оставляет таблицу Вготе на экране после 
выхода из сеанса работы с командой. Чтобы разместить на 
экране на две записи больше, чем обычно (на 25-строчном 
экране), применяется опция СОМРКЕ55, которая сжимает 
заголовки полей. 

Опция ЫОІІЧІТ позволяет переносить в данную команду 
установки всех опций из предыдущей команды ВКО>Ѵ$Е. После 
обновления индексированного поля записи она автоматически 
перемещается в новое место в соответствии с новым значением 
поля. Иногда требуется оставить запись после ее обновления на 
старом месте. Для этого используется опция И0Р0І-І-0>ЛЛ 
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Пример: 

ІІЗЕ ТгапзасЪ && Отбирает записи, обновленные в нарте 

5ЕТ РИТЕК ТО М0НТН(0а1е_1гапз) = 3 

60 ТОР 

йЕРІИЕ ѴІИООѴ Ѵіпі РКОМ 2,10 ТО 9,79 

ВКОУБЕ ИОАРРЕИО И0ЕРІТ НООЕЬЕТЕ ИОСІ-ЕАК ММЕМ; 

С0МРКЕ55 УІЫООУ Ѵіпі 

00 Иех*_ргд 

Выше в команде ВВО>Ѵ$Е была упомянута опция Ѵ^ІИООУ^, 
применяемая для активизации ранее созданного окна, в которое 
направляются выводимые командой ВВОѴ^ЗЕ данные. Для 
создания окна используется команда 

РЕРІИЕ <имя окна> 

РВОМ <строка 1>,<колонка 1> 

ТО <строка 1> г <колонка 1> 
[ООиВ1Е/РАИЕ1/ИОИЕ/<символы рамки > ] 
[СОЮВ [< стандартная область >] 

[,< нестандартная область >] [ г < рамка >]] 

которая устанавливает его размеры, местоположение на экране, 
рамку и цвет. Опции РВОМ и ТО определяют координаты левого 
верхнего и правого нижнего углов окна (номера строк и 
колонок), а опция РОУВІЕ/РАИЕЕ/ИОНЕ/с символы рамки > - 
тип рамки: двойная линия, полоса, без рамки или рамка из 
заданных символов. По умолчанию высвечивается одинарная 
линия рамки. Опция СОІ-ОВ позволяет установить цвета текста, 
фона и рамки. Для изменения параметров рамки и цвета 
используются специальные команды. Например, команда 

$ЕТ ВОВРЕВ ТО [5ІЫСЕЕ/РОІІВІ.Е/РАНЕІ./МОНЕ/ 

< символы определения рамки >] , 

изменяет параметры рамок окон и меню (см. разд. 3.6). Могут 
быть назначены различные символы для определения сторон 
рамки, которые записываются в виде 

[ < 1 > ['[ < ^ > ['[ < 3 > [>[ < 4 > [,[ < 5 > [,[ < 6 > [,[ < 7 > [,[ < 8 > ]]]]]]]] 
где цифры 1-8 обозначают десятичные коды А5СІІ любого 
символа, а также стороны и углы рамки (рис. 3.1). 

6 


8 

Рис. 3.1. Порядок расположения символов рамки 
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Команда $ЕТ ВОІШЕК ТО без опций восстанавливает символы 
рамки, принятые по умолчанию (одинарную линию). Опции 
5КНСІ.Е, ООІІВЫЕ, РАИЕІ., ИОИЕ задают соответственно одинар¬ 
ную, двойную, сплошную линии и без рамки. 

Пример: 

$ЕТ ВОКОЕК ТО 205,205,179,179,213,184,212.190 

Цвета и атрибуты экрана при работе с цветным и монохром¬ 
ным видеомониторами можно установить с помощью команды 

$ЕТ СОЮ* ОЫ/ОРР 

5ЕТ СОЮК ТО [[<стандартная область >] 

[,[< нестандартная область >] 

[,[< рамка >] [,[< фон >]]]]] 

$ЕТ СОЮК ОР ИОКМАІ/МЕ55АОЕ5/ТІИЕ5 
/ВОХ5/НІСНЫСНТ 
/ІНРОКМАТЮН/РІЕЮЗ 
ТО [< атрибуты цвета >] 

Первый вариант команды переключает на использование 
цветного (ОМ) или монохромного (ОРР) видеомонитора. По 
умолчанию принимается значение, заданное при запуске СІВА5Е. 

Второй вариант команды позволяет установить цвет текста и 
фона для стандартной и нестандартной областей экрана, а также 
цвет рамки. В качестве примера элементов стандартной и 
нестандартной областей экрана можно привести поля 5АѴ и СЕТ 
в команде @...$АѴ...СЕТ (см. разд. 3.4). Различный цвет этих 
элементов делает более удобной работу с экранной формой 
ввода и вывода данных. Полный состав элементов стандартной 
и нестандартной областей экрана приводится ниже. Цвет текста 
и фона в этих областях можно задать кодами цвета, разделен¬ 
ными! символом (/). 

Опция <фон> используется для адаптеров видеомонитора, 
на которых можно задать только один цвет фона стандартной и 
нестандартной областей экрана. При этом в каждой области 
сначала задается цвет текста, затем цвет рамки и фона. 

Команда 5ЕТ СОЮК ТО без опций восстанавливает принятые 
по умолчанию в СІВА5Е IV, а не установленные в файле 
СопЛд.сІЬ цвета экрана. При старте сІВАБЕ IV установки цвета, 
заданные в файле Сопіід.сІЬ, перекрывают установки, заданные 
по умолчанию. Третий вариант команды позволяет установить 
цвет групп элементов экрана, приведенных ниже. Кроме данной 
команды цвета можно установить с помощью опции ЭІ5РІ.АѴ 
команды 5ЕТ (см. разд. 3.4). Буквенные коды цвета, который 
можно назначить элементам экрана, приведены в табл. 3.2. 

После буквы, обозначающей цвет, можно указать символ * 
для мерцания или знак + для повышенной яркости (кроме 
коричневого, желтого и серого цвета). Если задана повышенная 
яркость, цвет воспроизводится более интенсивно. 
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Таблица 3.2. Коды цвета экрана 


Цвет 

Код 

Черный 

N или пробел 

Синий 

В 

Зеленый 

6 

Г олубой 

В6 

Пустой 

X 

Серый 

и+ 

Красный 

к 

Фиолетовый 

кв 

Коричневый 

6К 

Желтый 

ек+ 

Белый 

У 


Например, команда $ЕТ СОЮК ТО С/В Г КВ/Ы,ВС устанавливает 
зеленый текст на синем фоне в стандарной области, фиолетовый 
текст на черном фоне в нестандартной области и голубой цвет 
для рамки, а команда $ЕТ СОЕОК ТО В,С Г КВ,К высвечивает текст 
стандартной области синим цветом на красном фоне, текст 
нестандартной области зеленым цветом на красном фоне и 
задает фиолетовый цвет рамки. В последней команде можно 
устанавливать (изменять) не все, а отдельные цвета компонентов 
экрана, пропуская другие (разделители - запятые - должны 
оставаться). Например, если требуется установить зеленый цвет 
для рамки, не затрагивая остальных компонентов, следует 
указать: 5ЕТ СОЮК ТО гг С. При установке значений пар текст/ 
фон можно пропустить код, задающий цвет текста или фона. 
Если в паре текст/фон пропущен один из кодов, для этого 
параметра будет установлен черный цвет. Если высвечивание 
вводимых символов в заданной области экрана нежелательно 
(например, при вводе с клавиатуры пароля), следует задать для 
текста или фона этой области "пустой" цвет (X). 

Можно сохранить значения цвета элементов экрана в файле 
СопЛд.сІЬ, используя следующий синтаксис: СОЮК = 

< значения >. Параметры цвета в программах, созданных для 
цветного видеомонитора, имеют непредсказуемый эффект при 
переносе их на ПК с монохромным видеомонитором. 

При работе с монохромным видеомонитором можно задать 
код II для подчеркивания и код I для инвертированного изобра¬ 
жения вместо цвета с целью выделения стандартной и нестан¬ 
дартной области экрана. Вообще при переходе на другой 
монитор целесообразно убедиться в правильности реакции его 
адаптера на параметры цвета или коды II или I. 

Для определения типа адаптера монитора можно использо¬ 
вать функцию І$СОЮК(), которая возвращает логическое 
значение .Т., если установлен цветной графический адаптер. Эта 


6 - 6340 
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функция позволяет программно устанавливать коды цвета в 
зависимости от типа адаптера монитора. 

Пример: 

ІР ІБСОЮІЦ) 

$ЕТ СОЮК ТО 6К/В,Ѵ/К,6К 

ЕЬЗЕ 

БЕТ СОЮК ТО У+ 

ЕЫОІР 

При использовании третьего варианта команды можно 
установить цвета отдельных групп элементов, высвечиваемых на 
экране. В состав стандартной области экрана входят группы с 
именами ЫОКМАІ., МЕ55АСЕ5, ТІТІ.Е5, ВОХ, а в нестандартную 
область - группы с именами НІСНІ.ІСТН, ІЫРОКМАТІОЫ, РІЕЬОБ. 
В группу ЫОКМАІ. входят: информация, выводимая опцией $АѴ 
команды @...$АѴ...СЕТ, невыбранные поля таблицы Вготе, экран 
разработки запросов, отчетов и т.д., невыбранный текст на 
экране разработки, невыбранные нерасцвеченные шаблоны полей, 
рамки окон и статических полей Мето, условия в шаблоне файла 
и в окне, вычисляемые поля, невыбранные нерасцвеченные рамки 
в текстовом редакторе, нерасцвеченные рамки, ч рисуемые 
командой @...ТО, текст, введенный пользователем в генератор 
прикладных программ. В группу МЕ55АСЕ5 входят: информация, 
высвечиваемая в строке сообщений, в навигационной строке, 
невыбранные позиции меню и списков, внутренняя часть окна 
сообщений об ошибках, справочной информации и подсказок, 
имена файлов в окнах, жирный текст в окне справочной 
информации, невыбранные позиции окна подсказок, сообщений 
об ошибках и справочной информации. В группу ТІТЕЕЗ входят: 
заголовки списков, окна справочной информации и УЦ, заголовок 
каталога и его имя, имена файлов и заголовок их описания в 
УЦ, имена полей и сетка таблицы Вгож$е, заголовки, номера 
полей в таблице разработки структуры файла БД и линии этой 
таблицы, имя директория в верхней части окна имен файлов, 
имена файлов и данных для их сортировки, невысвеченные 
полосы экрана разработки отчета, имена файлов и их полей в 
шаблонах файла, шаблоны вывода и вычисляемых полей, а также 
линии этих шаблонов на экране разработки запросов, рамка и 
заголовок окна задаваемого условия отбора записей, линия 
разметки экрана в редакторе текста, участки текста, высвечи¬ 
ваемые опциями меню 5іуІе, подчеркнутый текст в окнах 
справочной информации. В группу ВОХ входят: рамки меню и 
информация о файле при его сортировке, рамки окна имен 
файлов и списков, сообщений и окна разработки марок, а также 
невыбранного компонента на экране генератора прикладных 
программ. В группу НІСНЫСНТ входят: подсвеченные позиции 
меню и списков, высвеченный текст на экранах разработки УЦ, 
выбранное окно, имена файлов и их описание в УЦ, курсор, 
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движущийся по линии разметки экрана, имена полос и высвечен¬ 
ные полосы экрана разработки отчета, рамки и внутренняя часть 
информационных окон, текущее поле в генераторе прикладных 
программ, рамки и поля на экранах разработки, на которых 
стоит курсор. 

В группу ІИРОКМАТІОЫ входят: часы, рамки окна ошибок и 
справочной информации и выбранные позиции в них, строка 
состояния на экране. В группу РІЕІ-РЗ входят: область ввода 
данных в сообщениях, выбранные поля в таблице ВКО>Ѵ$Е, 
редактируемые поля команды @...$АѴ...СЕТ, выбранное поле в 
таблице создания файла БД, редактируемые шаблоны полей на 
экранах разработки и невыбранные поля в генераторе приклад¬ 
ных программ. 

Пример: 

5ЕТ СОЮК ОР ІИРОКМАТІОМ ТО В+/6 

Если не требуется устанавливать различные цвета стандартной 
и нестандартной областей экрана, можно использовать команду 
$ЕТ ІИТЕМ5ІТУ ОРР (по умолчанию ОИ - цвета этих областей 
различаются). При этом, в частности, поля 5АѴ и СЕТ перемен¬ 
ных команды @...$АѴ...СЕТ рассматриваются как элементы 
стандартной области экрана. 

Чтобы созданные окна можно было многократно высвечивать, 
их нужно записать на диск командой 

5АѴЕ <список имен окон> 

/АН ТО <имя файла > 

По умолчанию имя файла окон имеет расширение .^іп. 
Можно задать другое расширение этого файла, указывая затем 
его при вызове окон. Опция АН ТО сохраняет в заданном 
файле все находящиеся в памяти окна. Для вызова окон с диска 
в память используется команда 

КЕ5ТОКЕ >УІИОО\Ѵ <список имен окон> 

/АН РВОМ <имя файла > 

Этой командой вызываются с диска (без их высвечивания) 
все сохраненные окна (опция АН) и выборочно в соответствии 
с заданным списком, в любом порядке, независимо от последо¬ 
вательности их сохранения командой 5АѴЕ ѴПИРОѴЛ Вызывае¬ 
мое с диска окно перекрывает окно с тем же именем, находя¬ 
щемся в памяти. После вызова в память окон командой 

АСТІѴАТЕ Ѵ/ІЫРОУ/ ссписок имен окон>/АН 

можно активизировать их - высветить на экране заданные в 
списке окна и направить поток информации в активное окно 
(последнее в списке). Опция АІ.І. высвечивает все окна, 
находящиеся в памяти, в последовательности их определения, 
последнее из которых будет активным. Если требуется снова 
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выводить информацию на весь экран, используется команда 
АСТІѴАТЕ 5СКЕЕН, которая восстанавливает доступ к полному 
экрану в отличие от доступа к части экрана, определенного 
последним активизированным окном. Это окно остается на 
экране, но перестает быть активным. Данную команду можно 
применять, например, для помещения текста вне окна в качестве 
справочной информации, после чего надо опять активизировать 
окно. 

Следует отметить, что при полноэкранном доступе вся 
информация, ранее выводимая в окно, будет теперь выводится 
на весь экран, в том числе и в область окна. Это приведет к 
перекрытию информации, оставшейся в окне или вызовет его 
перемещение за пределы экрана. Для полной очистки экрана 
можно использовать команду СІ-ЕАК. После повторной активиза¬ 
ции окно перекрывает информацию, которая попадает в область 
его размещения. 

МОУЕ >ѴІЫОО\У <имя окна> ТО <строка, колонка>/ВѴ 
< приращение строки, приращение колонки > 

Можно задавать координаты нового положения 
непосредственно или в виде приращения к текущей позиции. 

В поля Мето файла БД обычно записывается текст 
(например, пояснения к основным полям текущей записи этого 
файла), который нередко требуется вывести на экран в отдель¬ 
ное окно. Для этого можно использовать команду 5ЕТ \ѴІЫОО\Ѵ 
ОР МЕМО ТО <имя окна>. В этом окне поля Мето можно 
высвечивать командами АРРЕЫР, ВВО>Ѵ5Е, СНАЫСЕ, ЕОМ или 
(Э...5АѴ...СЕТ. Опция которая задана в командах 

@...СЕТ в экранной форме или в форме ВКО\У$Е, перекрывает 
окно, установленное данной командой (см. раздел 3.4). 

Альтернативой команды ВКО>У$Е является команда ЕРІТ 
(переключение с формы Вго\ѵ$е на форму ЕсІіТ и обратно 
осуществляется клавишей Р2): 

ЕРІТ [НОІНІТ] [ИОРОНОУ/] [ЫОАРРЕЫО] [МОМЕЫІІ] 

[ИОЕРІТ] [ИООЕІ.ЕТЕ] [ИОСЬЕЛР] [сномер записи>] 
[РІЕЮ5 <список полей >] [<диапазон>] 

[РОЛ <условие>] [\УНИЕ <условие>] 

Эта команда выводит на экран по одной записи файла БД, 
поля которой размещаются по вертикали. Если все поля не 
помещаются на одной стандартной странице экрана, то они 
продолжаются на следующих страницах, переход к которым 
осуществляется навигационными клавишами. Команда ЕРІТ также 
служит для вывода данных на экране в ранее разработанной 
форме (см. разд. 2.5). Для этого надо предварительно выпол¬ 
нить команду 5ЕТ РОКМАТ, чтобы установить файл экранной 
формы. 
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Описание опций команды ЕРИ, совпадающих с опциями 
команды ВКОѴѴ5Е, дано выше в описании этой команды. Опция 
<номер записи > позволяет после старта команды высветить 
сразу запись с заданным номером. Аналогичный результат можно 
получить, если использовать ключевое слово ЛЕСОЛР И опции 
<диапазон >, где N - номер записи. Различие между ними 
состоит в том, что в первом случае после обработки высвечен¬ 
ной записи можно передвигаться к другим записям файла БД, а 
во втором случае это сделать нельзя. Опции < диапазон >, РОЛ 
и \ѴНИЕ определяют диапазон выводимых записей, условия 
отбора и завершения процесса вывода записей. Напомним, что 
в качестве значений опции < диапазон > может использоваться 
упомянутое ключевое слово ЛЕСОЛй <Ы> (выводится запись 
с заданным номером), а также ИЕХТ <И> (выводятся N 
записей, начиная с текущей), АП (выводятся все записи) и ЛЕЗТ 
(выводятся записи, начиная с текущей до конца файла). Опция 
РОЛ позволяет высвечивать только те записи, которые удовлетво¬ 
ряют заданному условию. Опция >ѴНІІ.Е задает условие, по 
которому завершается вывод записей. 

Кроме команды ЕОІТ в командном языке сіВАЗЕ IV есть 
команда СНАИСЕ, также предназначенная для обновления данных 
в файле БД, синтаксис и использование которой полностью 
совпадают с командой ЕОІТ Команды ВКОѴѴ5Е и ЕОІТ имеют 
свое меню, которое описано в гл. 2. При работе с этими и 
другими полноэкранными командами для ускорения процесса 
ввода данных в поля файлов БД с клавиатуры используется 
команда 5ЕТ СОИРІКМ ОЫ (ОРР), которая устанавливает режим 
автоматического перехода курсора в следующее поле после 
заполнения предыдущего (ОРР) или оставляет курсор в 

последней позиции поля после его заполнения (ОЫ). Команда 
ЗЕТ ВЕН ои включает (устанавливается по умолчанию) 
предупреждающий звуковой сигнал при заполнении поля, вводе 
неверного значения поля и других ошибочных ситуациах (ЗЕТ 
ВЕН ОРР - отключает такое состояние). Для установки парамет¬ 
ров звукового сигнала используется команда 

ЗЕТ ВЕН ТО {<частота>,<длительность>] 

Частота измеряется в герцах, а длительность в единицах, 
равных 0.0549 с. По умолчанию задана частота 512 Гц и длитель¬ 
ность 2 единицы. Допустимый диапазон частоты от 19 до 10000 
Гц, а длительности от 2 до 19 единиц. Значение звукового 
сигнала можно также установить с помощью параметра ВЕН в 
файле СопЛд.сІЬ. Инициирование звукового сигнала выполняется 
функцией СНЛ(7) (см. разд. 3.7). 

Примеры: 

5ЕТ ВЕН ТО && Восстанавливает значение сигнала по умолчанию 

5ЕТ ВЕН ТО 500.12 
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? СНР(7) && Инициирует звуковой сигнал 

Команды ВКО>^$Е и ЕйІТ обеспечивают обновление содержи¬ 
мого полей в режиме ввода с клавиатуры. В ряде случаев 
возникает необходимость выполнять при обновлении многих 
записей стереотипные изменения, например умножить значение 
поля на одну величину и т.д. Для автоматизации такого вида 
обновления данных файла БД служит команда 

ІФРАТЕ ОЫ < ключевое поле> РВОМ салиао 

ВЕРЬ АСЕ <имя поля 1> >ѴІТН < выражение 1> 

[,<имя поля 2> >ѴІТН <выражение 2>...] 

[КАЫООМ] 

Эта команда заменяет содержимое полей исходного файла 
БД на данные, получаемые в результате вычисления (раскрытия) 
выражения, указанного в опции М^ІТН. В это выражение могут 
входить поля исходного файла, а также и файла из другой 
рабочей области, указанной опцией РВОМ. Последний файл также 
служит для отбора обновляемых записей в исходном файле 
посредством сравнения значений их общего поля (с одинаковым 
именем), которое указывается опцией <ключевое поле>. При 
совпадении значений этого поля в текущих записях этих файлов 
выполняется замена содержимого полей текущей записи 
исходного файла значениями указанных выражений. Если 
значение ключевого поля не уникально, то операция замещения 
выполняется только для первой записи с одинаковым значением 
ключевого поля. 

Оба файла должны быть либо отсортированы в восходящем 
порядке, либо проиндексированы по ключевому полю, если не 
задана опция КАИРОМ. В последнем случае только исходный 
файл должен быть проиндексирован по ключевому полю, а 
файл, указанный в опции РКОМ, может быть в любом порядке. 
Не рекомендуется обновлять ключевое поле, хотя это и не 
запрещается, поскольку по смыслу оно должно быть неизменным 
для обеспечения процесса поиска совпадающих полей. 

Если выражение в опции >ѴІТН включает поле из файла, 
указанного в опции РВОМ (что часто используется при 
обновлении), то его имя нужно записывать в виде: <алиас> -> 
<имя поля>. 

Пример: 

115Е Гіпапз ОКОЕР N 041 

РЕРІ.АСЕ АН То*а 1 УІТН О 

ІІ$Е Ріо ОРйЕР N041 ІИ 2 

иРОАТЕ (М N041 ГРОМ Ріо РЕР1.АСЕ Тоіаі; 

УИН Ріо->0к1асі*Ріо->Ргос 

И5Т 
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Если требуется обновить содержимое полей файла БД без 
привлечения данных из другого файла, например умножить 
содержимое числового поля на заданную величину, соединить 
содержимое двух символьных полей и т.д., можно использовать 
команду 

КЕРІ.АСЕ [< границы >] <поле> У/МИ < выражение > 

[, <поле> У / ІТН <выражение...] 

[^НИЕ <условие>] [РОК <условие>] [АйОІТІѴЕ] 

которая изменяет (замещает) значения заданных полей 
(включая поля Мето) текущей записи или группы записей, 
определенных границами и опциями ѴЖІІ.Е, РОК. Поле, значение 
которого обновляется, и выражение, указанное в опции >ѴІТН, 
должны иметь один и тот же тип данных. Для числовых полей 
значение выражения, указанное в опции >А^ІТН может превышать 
длину поля. В этом случае значение поля записывается в 
формате с плавающей запятой. При записи содержимого полей 
Мето в обычные поля часть поля Мето, не укладывающаяся в 
обычное поле, обрезается. Опция АРОІТІѴЕ позволяет не 
замещать, а добавлять текст, заданный опцией Ѵ^ІТН к содер¬ 
жимому полей Мето. Обновление значений проиндексированных 
полей файла БД вызывает автоматическое обновление файла 
индексов. Обновленная запись изменяет свое положение в 
индексном файле. Если в команде КЕРІ.АСЕ заданы границы и 
опции ^НИЕ, РОК, то могут быть обновлены не все записи. 
Например, если выполняется команда КЕРІ.АСЕ АН, то обновля¬ 
ется только первая запись и записи, значения которых следуют 
за новым значением этой записи. Это происходит вследствие 
того, что при обновлении выполняются изменения в индексе и 
указатель записи устанавливается на следующую за обновленной 
запись. Для гарантированного обновления значений всех записей 
следует использовать файл БД без индекса или установить на 
время обновления команду $ЕТ ОКРЕК ТО 0, а затем перестро¬ 
ить индекс командой КЕІКШЕХ. Команда КЕРІ.АСЕ не изменяет 
положение указателя записи, если не заданы границы обработки 
файла, опции МЖІІ.Е, РОК. 

Когда указатель записи стоит в конце файла (ЕОР() = .Т.), 
то обновление не выполняется, если в команде не указаны 
границы обработки файла или опция РОК. Перед выполнением 
команды КЕРІ.АСЕ для ее активизации следует установить 
указатель записи на начало файла с помощью команды СО ТОР. 

Примеры: 

ІІЗЕ Ріпапз 

КЕРЬАСЕ Регсепі ѴІТН 9.5 РОЙ Регсеп* =5.0 

КЕРІ_АСЕ АН ІЫісозІ ѴІТН ІІпПсозІ: * 1.1,; 

Регсепі ѴІТН Регсепі * 1.05 
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При использовании команд обработки файлов БД, которые 
включают списки полей (ВКОѴѴ5Е, ЕйІТ, 0І5РІ.АѴ И Др.), можно 
предварительно выполнить специальную команду по установке 
тех полей, которые требуется вывести на экран. Эта команда 
имеет три варианта: 

ЗЕТ РІЕЮЗ ОИ (ОРР) 

ЗЕТ РІЕЮЗ ТО [<поле> [/К]/<имя вычисляемого поля>...] 
[,<поле>[/В]/<имя вычисляемого поля>...] 
ЗЕТ РІЕЮЗ ТО АН [ЫКЕ/ЕХСЕРТ <шаблон>] 

Команда ЗЕТ РІЕЮЗ ТО определяет список доступных для 
вывода и обновления полей (включая вычисляемые поля) одного 
или нескольких файлов, а также позволяет устанавливать поля, 
которые соответствуют заданному шаблону. Кроме того, имеется 
опция К для установки на поле флажка “только чтение". 
Команда ЗЕТ РІЕЮЗ ОЫ активизирует установку полей. 

Команды ЗЕТ РІЕЮЗ ТО АН и ЗЕТ РІЕЮЗ ОРР делают 
доступными все поля активного файла БД. Опция АН ЫКЕ 
выводит поля, имена которых соответствуют заданному шаблону, 
а опция АН ЕХСЕРТ - поля за исключением заданных в 
шаблоне. Команда ЗЕТ РІЕЮЗ ТО без опций отменяет сделанные 
ранее установки полей. После определения списка доступных 
полей последущие команды ЗЕТ РІЕЮЗ ТО добавляют в этот 
список имена новых полей. Если установлено значение ЗЕТ 
РІЕЮЗ ОИ, то в командах и$Т 5ПШСТ1Л1Е и РІ5РІ.АѴ имена 
полей из заданного списка помечаются знаком >. 

Команда $ЕТ РІЕЮ5 ТО позволяет включить в список поля из 
нескольких файлов. Заметим, что связь между файлами при этом 
не устанавливается. Она устанавливается командой ЗЕТ КЕІ.АТІОН. 
Если среди файлов есть поля с одинаковыми именами, то нужно 
перед ними указывать алиасы рабочих областей со стрелкой 
вправо, например, А-><имя поля>. Список полей из команды 
ЗЕТ РІЕЮЗ ТО используется всеми командами, в которых можно 
задавать имена полей: АѴЕКАСЕ, ВКОѴ/ЗЕ, СНАИОЕ, СОРУ ТО, 

сору зтріістиРЕ, оізрьау, Ео і т, ют, изт, зіім, іоіаі. 

Для обеспечения целостности данных в выборках и связанных 
файлах при установке команды ЗЕТ РІЕЮЗ целесообразно 
добавлять записи по отдельности в каждый файл БД в состоянии, 
когда доступны все его поля. При изменении значений данных 
в индексированных полях связанных файлов БД следует помнить, 
что изменение данных в родительском файле без соответствую¬ 
щего изменения данных в сыновних файлах может привести к 
утрате связи между ними. Таким образом, в СІВА5Е IV не 
обеспечивается автоматическое обновление данных в связанных 
файлах. Команда ЗЕТ РІЕЮЗ не влияет на использование 
индексов, даже если индексные выражения содержат поля, не 
указанные в установленном списке. Этот список также не влияет 
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на команды ЮСАТЕ, 5ЕТ РИТЕК и $ЕТ ВЕІАТІОЫ, которым 
доступны все поля в открытых файлах БД. 

Для того чтобы связать файлы БД по общему ключевому 
выражению, используется команда 

5ЕТ КЕІ.АТІОИ ТО 

$ЕТ КЕЬАТЮИ ТО <ключевое выражение> ІИТО <алиас> 
[,< ключевое выражение> ІИТО <алиас>]... 

Эта команда связызает активный файл БД с открытыми 
файлами в других рабочих областях, которые указываются 
алиасами в опции ІНТО. Активный файл БД, который управляет 
связью, называется родительским, а связываемые с ним 
файлы - сыновними. Команда 5ЕТ &ЕІ.АТІОИ ТО без опций 
отменяет установку связи в текущей рабочей области. В качестве 
ключевого выражения можно использовать общее поле или 
комбинацию полей, например сцепление символьных полей или 
их подстрок, а также любые другие разрешенные выражения. 
Кроме этого типа связи в качестве ключевого выражения можно 
использовать функцию КЕСЫО(), обеспечивающую связь по 
физическому номеру записи. Если при работе со связанными 
файлами БД не удается найти запись в сыновнем файле, то 
указатель записи в нем устанавливается в конец файла и 
значение функции ЕОРП равно .Т. В сыновних файлах не 
действует команда 5ЕТ ЙЕАК. 

Напомним, что связанные файлы образуют выборку. Для ее 
сохранения (вместе с установками среды) используется команда 
СКЕАТЕ ѴВЕѴ/ <имя выборки> РКОМ ЕЫѴІКОНМЕМТ. Эта 
команда создает и сохраняет на диске файл выборки 
(с расширением .ѵие) (совместимый с СІВА5Е 111 + ), в котором 
записывается следующая информация активной текущей среды: 

все открытые файлы БД, индексные файлы и рабочие 
области каждого файла; 

все связи между файлами БД; 
номер текущей рабочей области; 
список активных полей файлов; 
открытый файл экранной формы (.(ті); 
установленный фильтр. 

Если установлена команда $ЕТ САТАЮС ОЫ и открыт 
каталог, то выборка автоматически записывается в него. После 
сохранения эту выборку можно активизировать командой $ЕТ 
ѴІЕ\У ТО <имя выборки >. Для деактивизации файла выборки 
можно открыть другой файл выборки или выполнить команду 
СЮ5Е РАТАВА5Е5, которая закрывает все открытые файлы БД 
и связанные с ними файлы, образующие выборку. Формирование 
и сохранение выборок можно выполнить с помощью команды 
СВЕАТЕ/МСЮІРѴ У ІЕѴ/, меню которой описано в разд. 2.4. 
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Пример: 

5ЕІ.ЕСТ 1 

Ц$Е По ОКОЕК Раш 
5ЕІ.ЕСТ 2 
ІІ5Е Ипалз 
ЗЕІЕСТ 3 

113Е Косі ОШ* Раш 
ЗЕІЕСТ 2 

ЗЕТ НЕЦЕЛОЙ ТО Раш ШО Ріо, Раш ШО Косі 
И5Т Р1о->Раш, Когі->Иот, Рау 

Для обеспечения множественной обработки записей в 
связанных файлах БД используется команда $ЕТ 5КІР ТО 
[<алиас> [,< алиао ]...], Она также позволяет осуществить 
доступ ко всем записям связанных файлов БД, которые удовлет¬ 
воряют заданному значению ключевого выражения (по которому 
установлена связь командой ЗЕТ &ЕІ.АТІОИ). Обработка записей 
в связанных файлах БД выполняется в последовательности, 
определенной цепочкой алиасов, начиная с сыновних файлов и 
кончая родительским файлом. Родительский файл может быть 
первым в цепочке или же вообще не включаться в* нее, но в 
любом случае он обрабатывается последним. 

Пример: 

5Е1.ЕСТ 3 

УЗЕ Косі ОМЕК Раш 
ЗЕІЕСТ 2 

ІІ5Е Ріпапз ОКОЕК Раш 

ЗЕТ ЯЕЬАТІОЫ ТО Раш ІИТО Кос* 

ЗЕІЕСТ 1 
ЦЗЕ Ріо 

ЗЕТ КЕІ_АТІ0Ы ТО Раш ШО Ріпапз 
ЗЕТ 5КІР ТО Косі,Ріо,Ріпапз 
ІЛ5Т Р1о,Р1папз->Рау,КосІ->Мот 

При использовании команд АРРЕЫО, ВКОѴ^ЗЕ, ЕОІТ на экране 
(чаще всего в нижней строке экрана - строке сообщений) 
появляются различного рода сообщения и подсказки. В ряде 
случаев (например, когда пользователь уже хорошо освоил эти 
команды и хочет их модифицировать) возникает желание не 
выводить эти сообщения. Для этого используется команда ЗЕТ 
ШЗТІШСТ ОИ (ОРР), которая устанавливает режим их высвечива¬ 
ния (ОН) или подавления (ОРР). 

После ввода данных в файл БД нередко требуется быстро 
их просмотреть. Для этого служат команды 

Ы5Т/ОІ5РІ.АѴ [< границы >] [[РІЕЮ$] <список выражений:»-] 
[ОРР][< диапазон >] [РОК < условие >] 
[У^НИЕ <условие>] [ТО РКШТЕК/ 

ТО РНЕ <имя файла>] 
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Эти команды выводят все поля файла БД, если их список не 
определен опцией ЕІЕІ.05. В начале каждой записи, если не 
указана опция ОРР, выводится ее номер. Как уже упоминалось, 
опции < диапазон >, РОК и \ѴНІІ-Е определяют диапазон 
выводимых записей (см. раздел 3.1). Кроме них отбор выводи¬ 
мых записей определяется также предварительной установкой 
команд 5ЕТ РІІ.ТЕК и 5ЕТ йЕ1_ЕТЕ0. Первая команда подключает 
заранее разработанный файл запроса, а вторая устанавливает 
режим пропуска записей, помеченных для удаления. Команды 
Ы5т и оі$рі_аѵ идентичны с той разницей, что первая выводит 
записи непрерывно, а вторая делает остановку после вывода 
одной страницы экрана. Команда 5ЕТ РАІІ5Е ОИ (ОРР - по 
умолчанию) также позволяет выводить любую информацию 
страницами экрана. При выводе данных файла БД на каждой 
экранной странице высвечиваются заголовки полей. Эта команда, 
кроме того, определяет постраничный вывод данных командой 
5ЕІ.ЕСТ языка 501. (см. гл. 4). 

Действие команды ЗЕЬЕСТ в языке 501 при 5ЕТ РАІІ5Е ОИ 
аналогично команде 0І5РІ.АѴ, а при $ЕТ РАЫ$Е ОРР - команде 
И5Т 

Содержимое поля Мето выводится, если его имя указано в 
списке полей. Вывод выполняется в колонках шириной 50 
позиций. Ширину вывода можно изменить командой 5ЕТ 
МЕМО>ѴЮТН ТО <выр.Ы>. Если имя поля Мето не указано в 
списке полей, то вместо содержимого поля выводится слово 
(маркер) тето или МЕМО. Прописные буквы указывают на 
заполненность, а строчные на отсутствие содержимого поля 
Мето. Если записи имеют длину больше 80 символов, то они 
разворачиваются на экране с разрывом содержимого на 80-й 
позиции. Опции ТО РРІИТЕК и ТО РНЕ позволяют вывести файл 
на принтер или записать на диск. Если перед выводом установле¬ 
на команда 5ЕТ НЕАРІИО ОЫ, то высвечиваются имена полей. 
Эта команда выводит имена полей и при выполнении других 
команд, например 51ІМ, АѴЕКАСЕ. Для вычисляемых полей в 
качестве имен используется вычисляемое выражение. Если слово 
РІЕІ.05 записывается строчными (прописными) буквами, то и 
заголовки выводятся строчными (прописными) буквами. 

Кроме вывода файлов БД команды І.І5Т и РІ5РІ.АѴ позволя¬ 
ют также высвечивать данные о файлах в директориях, содержи¬ 
мое буфера НІ5ТОКѴ (хранилище выполненых с клавиатуры 
команд), данные об используемых переменных и массивах, 
информацию о текущем сеансе работы с СІВА5Е IV, структуру 
указанного файла БД и имена рабочих станций, работающих в 
среде ЛВС. Для вывода информации о файлах в директориях 
аналогично команде оо$ аіг можно использовать команду 

Ы5Т/ОІ5РІ.АѴ РІІ.Е5 [ЫКЕ <шаблон>] 

[ТО РРЖТЕК/ТО РНЕ <имя файла>] 
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В этой команде шаблон предназначен для выбодэ файлов с 
именами (включая расширение), имеющими общую часть. Если 
не задано имя файла или его шаблон, то выводится информация 
о всех файлах БД в текущем директории, включая имя файла, 
число записей в нем, дату последнего обновления, размер файла 
в байтах, полное число высвеченных файлов, общий объем 
занимаемой памяти и объем свободной памяти на диске. 

Следует отметить, что данные об открытых файлах могут не 
отражать текущее их состояние (число записей и объем), если 
установлена команда $ЕТ АІІТ05АѴЕ ОРР. В этом случае 
актуальность данных восстанавливается после закрытия файлов. 

Как уже упоминалось, все выполняемые в режиме набора с 
клавиатуры команды заносятся в специальный буфер, называемый 
НІ5ТОКѴ. Эти команды можно вызвать из буфера, что полезно 
при отладке программ, так как экономит время на набор 
команд. Для просмотра содержимого буфера НІ5ТОКѴ использу¬ 
ется команда 

и$Т/ОІ$РІ.АѴ НІ5ТОКѴ [І.А5Т <выр. И>] 

[ТО РРШТЕК/ТО РНЕ <имя файла>] 

которая выводит список всех выполненных в режиме набора с 
клавиатуры команд (или последние команды, число которых 
задается опцией 1.А5Т), которые были записаны в этот буфер. По 
умолчанию в буфере помещается 20 команд. Его объем можно 
изменить командой 5ЕТ НІ5ТОКѴ. 

При разработке больших программ важно экономно расходо¬ 
вать оперативную память. Для этого используются различные 
способы оптимального распределения памяти. При этом нужно 
знать, сколько оперативной памяти занимают различные компо¬ 
ненты программы. Для оценки распределения оперативной 
памяти можно использовать команду 

И5Т/ОІ5РІ-АѴ МЕМОКѴ [ТО РКШТЕК/ТО РНЕ <имя файла>] 

которая выводит информацию об используемых активных 
переменных и элементах массивов: имя, статус (рденс или 
РКІѴАТЕ), тип и значение переменной, а также имена, определе¬ 
ния и емкость памяти, занимаемой активными окнами, вертикаль¬ 
ными и горизонтальными меню и их позициями, значения всех 
системных переменных, а также емкость остающейся памяти. 
Максимальное количество переменных определяется установками 
параметров МѴВІ.К5ІІЕ и МѴМАХВІ.К5 в файле Сопіід.сІЬ. 
Первый параметр определяет размер блока памяти переменных 
в единицах (участках памяти по 56 байт), отводимых для одной 
числовой, логической или типа даты переменной, а второй - 
максимальное число таких блоков. По умолчанию устанавливается 
МѴВІ.К5І2Е = 50 и МѴМАХВІ.К5 = 10, что позволяет хранить 

до 500 числовых переменных. Для массивов переменных один 
такой участок отводится под его имя, а специальный блок 
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участков - под элементы. Символьные переменные и массивы 
занимают несколько участков в зависимости от длины содержи¬ 
мого. В целях обеспечения поиска ошибок при выполнении 
команд для каждой переменной и поля файла БД отводится 
дополнительный участок памяти для отладочной информации. 
Общая емкость этой памяти определяется параметрами 
КТВІЖ5І2Е и КТМАХВІ.К5, задаваемыми в файле Сопіід.сІЬ. 
Первый параметр определяет размер блока памяти для отладоч¬ 
ной информации в единицах по 17 байт, а второй - максималь¬ 
ное число таких блоков. По умолчанию &ТВІ.К5І2Е = 50 и 

&ТМАХВІ.К5 = 10. Оперативная память занимается блоками 
переменных и отладочной информации по мере их объявления 
и заполнения очередного блока. Кроме участков памяти, 
отводимых под содержимое переменных и отладочную информа¬ 
цию (кроме символьных переменных), имеются участки памяти, 
обеспечивающие их вывод. Для каждой переменной типа даты 
требуется еще 8 байт, для логической переменной 1 байт и для 
числовой - 20 байт. В последней строке выведенной командой 
и$ТД)І$РІАѴ МЕМОКѴ информации содержится общая емкость 
дополнительной памяти, требуемой для высвечивания перемен¬ 
ных. В эту емкость также входит емкость памяти, занимаемая 
системными переменными, равная 264 байтам. Такое подробное 
описание памяти, выделяемой для переменных, полезно для 
определения ее оптимальной емкости и распределения между 
переменными и другими компонентами программы, например 
окнами или меню. 

Полную информацию о состоянии среды можно получить 
командой Ы5Т/ОІ5РІ.АѴ 5ТАЮ5, которая выводит: номер текущей 
рабочей области, имя файла БД, его алиас и маршрут по 
директориям, признак установки режима только чтения файла 
(если установлен), открытые индексные файлы (типа .псіх и 
.тсіх), индексные выражения для каждого индексного файла и 
указателя, их опции ІІИЮІІЕ и ОЕ5СЕИОІЫС, открытые файлы 
полей Мето, формулы фильтров для отбора записей, связи 
файлов БД, файлы экранных форм, маршруты для поиска 
файлов, диск, установленный по умолчанию, устройство для 
вывода печатаемых материалов, загруженные программные 
модули, текущую выбранную рабочую область, левую границу 
вывода на печать, текущий открытый файл процедур, счетчик 
повторения захватов, счетчик количества проверок обновления 
файлов, значение параметра РЕѴІСЕ (5С&ЕЕИ, РКІЫТ или РНЕ), 
символ валюты, символ разделителя полей файла БД, количество 
открытых файлов, установки команды ОИ, текущие значения ОЫ 
или ОРР большинства $ЕТ -команд и назначения функциональных 
клавиш. 

В сложных информационных системах количество файлов БД 
бывает достаточно велико. Нередко возникает необходимость 
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просмотреть структуру файла и вывести ее на печать. Для этого 
служит команда 

Ы5Т/ОІ5РІ-АѴ $ТІШСТи&Е [ІИ <алиас>] [ТО РКІИТЕЙ/ 

ТО РНЕ симя файла>] 

которая выводит информацию о файле БД в текущей рабочей 
области или заданной алиасом: имя файла, число записей, дату 
последнего обновления, полное определение каждого поля 
(имя, тип, ширину и т.д.), поля, являющиеся указателями 
связанного файла .тсіх и общий размер записи в байтах, который 
складывается из размеров полей плюс один байт, служащий для 
пометки записи на удаление. Опции ТО РРІЫТЕР и ТО РНЕ для 
всех команд И5Т/ОІ5РІ.АѴ позволяют вывести информацию на 
принтер или записать в файл на диск. 

Команды ВКОѴѴ5Е и ЕОІТ позволяют выполнять все действия, 
необходимые для ввода, обновления, удаления и добавления 
записей с использованием меню этих команд, которые дают 
возможность передвигатся по файлу, помечать записи для их 
последующего удаления, вводить и обновлять с клавиатуры 
данные. Кроме этих команд существуют специальные команды 
перемещения по файлу, добавления новы* записей и пометки 
записей для их последующего удаления. Обычно эти команды 
используются в программах для обеспечения автоматизированной 
обработки информации, но могут также применяться в режиме 
набора с клавиатуры. Перед тем как выполнять команды в этом 
режиме, необхЬдимо файл БД открыть. После этого можно 
выполнять с ним операции. Для перемещения по файлу исполь¬ 
зуется команда 

СО/СОТО ВОТТОМ/ТОР [ІИ <алиас>] 

или 

СО/СОТО [КЕСОКР] <номер записи> [IN салиао] 

или 

< номер записи > 

Эта команда осуществляет переход на указанную запись в 
активном файле БД. Если индексный файл открыт, опции ТОР и 
воттом осуществляют переход к первой и последней записям 
индексного файла. Если же индексный файл не используется, эти 
опции осуществляют переход к первой и последней физическим 
записям файла БД. Для выполнения перехода к записи по 
физическому номеру используется опция СО или просто ее 
параметр < номер записи >. 

В программах часто требуется перемещать указатель записи 
не на конкретную запись, а на следующую после текущей. Такое 
перемещение необходимо при организации циклов обработки 
файла БД. Эту операцию выполняет команда 5КІР [<выр.И>] 
[ІН <алиас>]. Указатель записи в активном файле БД в текущей 
рабочей области (или в области заданной опцией ІЫ) можно 
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перемещать вперед или назад в зависимости от знака числового 
выражения, определяющего количество пропускаемых записей. 
Если с файлом БД используется индекс, указатель перемещается 
в соответствии с индексом. Для неиндексированных файлов БД 
указатель перемещается по физическим номерам записей. Если 
выражение не/ указано, указатель перемещается вперед на одну 
запись. Опция ІИ позволяет перемещать указатель записи в 
другой рабочей области без ее выбора командой 5ЕІ.ЕСТ в 
качестве текущей. При этом указатель записи в текущей рабочей 
области не изменяется. Если установлена команда $ЕТ ТАІ.К ОИ, 
то при высвечивании данных на экране выводится номер записи. 

При работе с индексными файлами в среде ЛВС следует 
быть особенно внимательными, выполняя команду 5КІР (более 
подробно см. разд. 3.7). Если один из пользователей изменяет 
значение индексированного поля файла БД или добавляет запись 
к нему, то после этого весь файл переупорядочивается в 
соответствии с установленным главным индексом. Это надо иметь 
в виду при установке командой $КІР указателя на обновленную 
запись или запись, следующую после нее, поскольку ее располо¬ 
жение уже изменено в результате появления обновленной или 
новой записи. Напомним, что упорядочивание индексированного 
файла БД означает не физическое изменение положения записей, 
а соответствующее построение индексного файла, который 
определяет вывод данных. Физическое расположение записей 
при этом не меняется. 

Например, если один пользователь добавляет запись в файл, 
а другой пытается командой $КІР перейти на эту запись, то 
указатель записи будет показывать конец файла. Если же один 
пользователь обновляет значение индексированного поля 
некоторой записи, а другой пытается перейти на следующую за 
ней запись, то указатель записи также будет установлен не на 
эту, а на совершенно другую запись. Для того чтобы избежать 
таких неприятностей, можно сначала выполнить команду СО 
КЕСИОО для установки указателя на текущую запись, а 
затем - команду $КІР. 

При использовании команды 5КІР в программах для переме¬ 
щения по файлу часто требуется получить признак его начала 
или конца. Для этого применяются функции ВОР() И ЕОР(). 
Функция ВОР([<алиас>]) определяет начало файла и возвраща¬ 
ет логическое значение .Т., если предпринимается попытка 
переместить указатель перед первой записью, в противном 
случае возвращается .Р. Следует отметить, что значение .Р. 
возвращается и в том случае, если вообще нет открытого 
файла БД. Аналогично индицирует конец файла функция 
ЕОР([<а ли а с >]). В программах и режиме выполнения команд 
с клавиатуры нередко требуется определить текущий номер 
записи. Это осуществляется функцией КЕСЫОЦолиао]), 
которая возвращает текущий номер в указанном файле БД. Если 
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алиас не задан, то подразумевается текущая рабочая область 
Возвращается 1, если в файле БД записей нет, и 0, если нет 
открытых файлов БД. Если указатель записи перемещается на 
следующую после последней запись в файле БД, то возвращает¬ 
ся число, на единицу большее количества записей в файле и 
ЕОРО = т. Если указатель записи перемещается на запись, 
предшествующую первой записи файла БД, что эквивалентно 
выполнению команды 5КІР-1, то возвращается 1 и ВОРО = т. 


Примеры: 


Ы$Е Ріо 
5КІР 

5Т0КЕ 5 ТО іпзкір 
5КІР шзкір 
$КІР-3 

УЗЕ Ріпапз ІИ 2 
$КІР 4 ^ Ріпапз 


&& Пропуск одной записи вперед 
&& Для пропуска пяти записей 
&& вперед используется переменная 
&& Переход на три записи назад 
&& Перемещает указатель записи в 
&& файле БД Ріпапз, тогда как 
активным является файл БД Ріо 


После того как указатель записи перемещен на нужную 
запись, которая становится текущей, можно выполнить требуемую 
операцию, например ввести запись до или после текущей. Для 
этого используется команда ІИ5ЕКТ [ВЕРОВЕ] [ВІ.АНК], которая 
позволяет ввести новую запись (или пустую запись, если указана 
опция КН.АИК) после текущей или перед ней (если задана опция 
ВЕРОВЕ). Пометить одну или несколько записей для их последу¬ 
ющего удаления можно командой ЭЕІ.ЕТЕ [< диапазон >] 
[РОК < условие >] [>^НИЕ <условие>]. Опции <диапазон>, РОВ 
и Ѵ/ННЕ позволяют помечать записи, отобранные в соответствии 
с заданным диапазоном и условиями. 

В программах нередко требуется определить, помечена ли 
текущая запись для удаления. Это можно сделать с помощью 
функции ОЕІ.ЕТЕО([< алиас >]), которая возвращает логическое 
значение .Т. для помеченной записи. 

Для того чтобы уничтожить пометки на удаление записей 
используется команда 


КЕСАИ [<диапазон>] [РОК<условие>] [>ѴНИЕ<условие>] 

Опции < диапазон>, РОК и >ѴНИ.Е как обычно определяют 
дипазон, условия отбора записей и прекращения этой операции. 
Перед уничтожением пометок на удаление должна быть 
установлена команда 5ЕТ РЕ1.ЕТЕ0 ОН. Эта команда включает 
(ОРР выключает) режим пропуска помеченных на удаление 
записей при обработке файла БД многими командами СІВА5Е IV 
(например, І.ОСАТЕ, Ы5Т, КЕСАИ и др.) кроме команд ІЫРЕХ, 
КЕІЫРЕХ, 0І5РІ.АѴ и СОТО, которые обрабатывают, выводят и 
устанавливают указатель на любую запись независимо от 
установки $ЕТ ОЕЬЕТЕО. Если установлена команда $ЕТ ОЕЬЕТЕО 
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ОЫ, то пометку одной записи с номером N можно уничтожить 
командой КЕСАЫ. РЕСОКО И 

Примеры: 

УЗЕ По 

КЕСАЫ. && Уничтожает метку удаления текущей записи 

КЕСАИ. КЕСОКО 10 && Уничтожает метку удаления записи 10 

КЕСАИ АН && Уничтожает все метки удаления записей 

* активного файла БД 

Физическое удаление помеченных записей активного файла 
БД выполняет команда РАСК. При этом происходит автоматичес¬ 
кое перестроение всех открытых индексов (выполняется команда 
КЕІИОЕХ). После выполнения команды РАСК и закрытия файла, 
дисковое пространство, занятое исключенными записями, 
становится доступным для ввода. Для удаления всех записей 
активного файла БД без их предварительной пометки использует¬ 
ся команда 2АР. Удаление всех записей можно также осущест¬ 
вить с помощью последовательного выполнения команд ОЕІ.ЕТЕ 
АН и РАСК, но команда 2АР работает быстрее. Следует 
отметить, что индексные файлы, связанные с уничтоженным 
файлом БД, остаются и переиндексируются на оставшуюся одну 
пустую запись файла БД. 

Важной операцией при работе с файлами БД является 
добавление записей в конец. Она обычно используется при 
первоначальном вводе данных, а также и в процессе эксплуата- 
информационной задачи. Как уже отмечалось, команда 
позволяет выполнять все основные операции по вводу, 
обновлению и добавлению данных. Кроме этой команды в языке 
СІВА5Е IV имеются специальные команды для добавления записей 
в конец файла БД с клавиатуры, из другого файла, из массива 
данных и т.д., которые могут использоваться в программах и в 
командном режиме. Команда АРРЕЫР [ВІ.АИК] позволяет 
добавлять записи, введенные с клавиатуры в конец активного 
файла БД (или пустую запись, если указана опция ВЬАЫК). По 
умолчанию для ввода используется экранная форма команды 
ЕйІТ или экранная форма, установленная командой $ЕТ РО&МАТ 
ТО. При добавлении записей все активные индексные файлы 
автоматически обновляются. Если установлено состояние $ЕТ 
АІЛО$АѴЕ ОМ, то запись на диск осуществляется автоматически 
после каждой единичной операции ввода-вывода, кроме послед¬ 
ней записи, которую нужно сохранить клавишами СігІ-ЕпсІ. В 
состоянии $ЕТ АІІТ05АѴЕ ОРР (устанавливается по умолчанию) 
добавленные записи сохраняются автоматически только после 
заполнения буфера. Состояние ОН или ОРР этой команды может 
быть установлено в командном режиме с помощью команды 5ЕТ 
и в файле СопЯд.сІЬ. При выполнении операций по обновлению 
данных нередко требуется перенести значения предыдущих 
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полей записи в последующие. Для этого можно использовать 
команду 

$ЕТ САРКУ ТО [< список полей> [АйОІТІѴЕ]] 

которая копирует данные из предыдущей записи в последующую 
запись при обновлении данных командами ВКОѴ^ЗЕ, АРРЕИй или 
Ш5ЕКТ (кроме команд ІЫ5Е&Т ВЬАИК и АРРЕИй В1.АИК). При 
задании списка полей копируются только указанные в нем поля. 
В этом случае команда 5ЕТ РІЕЮ5 не действует. Опция 
АРРІТІѴЕ добавляет значения полей из предыдущей записи к 
соответствующим полям последующей записи. Если список полей 
не указан, то копируются все поля. Состояние $ЕТ САРРУ ОИ 
(ОРР устанавливается по умолчанию) включает (выключает) 
копирование полей. 

Для добавления записей в активный файл БД из другого 
файла, в том числе не относящегося к сІВАЗЕ, используется 
команда 

АРРЕНР РРОМ <имя файла>/? 

[[ТУРЕ] <тип файла >] [РОР < условие >] 

Опция <тип файла> имеет следующие значения: 

СІВА5ЕІІ - файл сІВАЗЕ II; 

ОЕІ.ІМІТЕО - файл А5СІІ формата ОЕІ_ІМІТЕО; 

йЕЫМІТЕО \УІТН ВІ_АЫК - файл с полями, разделенными 
одним пробелом, и записями, разделенными знаком возврата 
каретки и конца строки; 

ОЕЫМІТЕР ѴПТН < разделитель> - файл с полями, отделен¬ 
ными запятыми и символьными данными, заключенными в знак 
разделителя (по умолчанию кавычки); 

РІР - файл формата Ѵі$іСаІс; 

РУ/2 - файл БД или электронной таблицы Ргатеѵѵогк II; 

РРР - файл данных РарісІРіІе; 

5йР - файл А5СІІ системного формата; 

5ѴІ.К - файл электронной таблицы МиЖРІап; 

>УК$ - файл электронной таблицы І_оіи$ 1-2-3, версия ІА. 

Строки данных в электронных таблицах интерпретируются как 
записи, а колонки в них, как поля. 

В разд. 3.1 была отмечена функция переменных и массивов 
как временных промежуточных хранилищ данных. Данные из 
переменных и массивов можно передавать в файл БД и обратно. 
Для добавления данных из массива в конец активного файла БД 
используется команда 

АРРЕИО РРОМ АРРАУ <имя массива > [РОК < условие >] 

Строки массива переводятся в записи, а колонки в поля. Если 
в массиве больше колонок, чем полей в файле БД, то лишние 
колонки игнорируются. Если в файле БД больше полей, чем 
колонок в массиве, то лишние поля остаются пустыми. Каждый 
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элемент массива должен быть того же типа, что и тип поля, в 
которое он помещается. Если используется опция РОЛ, то 
условие оценивается перед помещением строки массива в файл 
БД. Условие должно включать имя поля из файла БД. Строка 
добавляется в том случае, если условие оценивается как .Т. Если 
условие оценивается как .Р., то строка пропускается и обрабаты¬ 
вается следующая строка. Массив должен быть заранее объявлен 
и инициализирован. 

Пример: 

0ЕС1.АКЕ Мазз1ѵ[1,5] 

Мазз іѵ [1,1]=”Петров” 

Маз5Іѵ[1 ,2]=”923-15-48" 

Наззіѵ [1,3]=0АТЕ() 

Мазз1ѵ[1,4]=.Т. 

Мазз1 ѵ [1 г 5]=250.00 

и$Е Касіг 

АРРЕМ ГРОМ АРРАУ Мазз 1 ѵ 

Предыдущие команды добавления записей в конец файла БД 
позволяют вводить данные и в поле Мето. Но из-за специфики 
данного поля используются специальные команды по его 
обработке, например, команда 

АРРЕИй МЕМО <имя тето поля> 

РВОМ < имя файла > [ОѴЕРѴ/РІТЕ] 

Эта команда позволяет ввести данные, если поле пустое, 
добавить к имеющемуся содержимому текущего поля Мето 
данные или перекрыть содержимое, если используется опция 
ОѴЕК^КІТЕ, данными из заданного текстового файла. Если не 
указывается расширение файла, то подразумевается Лхі. 

Пример: 

у$е по 

АРРЕИО МЕМО регзоп аі ГРОМ ТхНЧІе 

К числу команд по созданию файлов БД можно также 
отнести команду ІМРОРТ РВОМ <имя файла> [ТУРЕ] РР$/ОВА$Е 
I І/Р>У2/РРО/Ѵ/К1 которая формирует файл БД сШАЗЕ IV с 
расширением .СІЫ (и присваивает ему имя исходного файла) из 
файлов формата РР$, ЭВА5Е II, РѴ/2, РРЭ и ѴѴК1. Для импорта 
файлов СІВА5Е II нужно изменить их расширение с .СІЫ на .сІЬ2. 

Следует учитывать, что при импорте преобразование внешних 
файлов осуществляется в соответствии со структурой, размерами 
и типами файлов СІВА5Е IV. При импорте файлов формата РР5 
создаются три типа файлов сШАЗЕ IV: файл БД (.СІЫ), исходный 
(Лті) и компилированный (.(то) файл экранной формы. 

Выше рассматривалось упорядочивание вывода данных из 
файлов в соответствии с заданными индексами. При таком 
упорядочивании физическое расположение записей исходного 
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файла не меняется. В ряде случаев требуется создать физически 
упорядоченный файл. Для этого используется команда 

$ОКТ ТО <имя файла > ОИ <поле1> [/А] [/С] [/О] 

[,<поле2> [/А] [/С] [/0]...][А$СЕМОШО]/[ОЕ$СЕНОтО] 
[<границы>] [^НИЕ <условие>] [РОЛ <условие>] 

которая создает новый файл БД с записями, отсортированными 
в алфавитном, хронологическом или числовом порядке по 
заданным полям. Сортировка выполняется в порядке возрастания 
(/А) или убывания (/О) значений полей. Допускается сортиров¬ 
ка максимум по десяти полям. Опция /С определяет сортировку 
независимо от прописных и строчных букв. 

Запрещается сортировать по логическим полям и полям 
Мето, по подстрокам и выражениям. Для того чтобы получить 
отсортированный файл по подстрокам и выражениям, можно 
использовать две другие команды. Сначала команду ІЫОЕХ, 
позволяющую создать индексный файл по заданному выражению, 
а затем команду СОРѴ, которая создает копию файла с запися¬ 
ми, упорядоченными по индексному выражению. Отсортирован¬ 
ный файл БД нельзя записывать в себя или в любой другой 
открытый файл. 

Ключевые слова А5СЕЫ0ІЫС и 0Е5СЕЫ0ІЫС можно использо¬ 
вать в качестве альтернативы значениям /А и /О. Можно 
комбинировать опцию /С с опциями /А или /О. Если использует¬ 
ся комбинация опций, нужно указывать только один разделитель 
(например, /ОС). При сортировке по нескольким полям, 
наиболее приоритетное поле следует указывать первым. 

Пример: 

115Е Ріо 

БОЛТ (М 01(1 ТО 01(11 

После создания файла БД часто возникает необходимость его 
копирования, например для создания дубликата, с целью 
последующей модификации файла и т.д. 

Команда СОРУ РНЕ <имя файла 1> ТО <имя файла 2> 
делает копию файла любого типа. Имена копируемого 
(исходного) файла и выходного файла (куда копируется 
исходный файл) должны указываться с расширением, и при 
необходимости именам файла должен предшествовать идентифи¬ 
катор диска и маршрут по директориям (если используется диск 
и директорий, отличный от текущего). Не требуется указывать 
идентификатор диска, где размещен файл 1, если он задан с 
помощью команды $ЕТ РАТН (или РАТН = < маршрут по 

директориям> в файле Соп(ід.сІЬ). Запрещается копировать 
открытые файлы. При копировании файла БД, содержащего поля 
Мето, соответствующий файл .сІЬі должен копироваться отдель¬ 
но. Это же относится и к связанному индексному файлу типа 
.тсіх. Перед копированием целесообразно убедиться в том, что 
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на диске достаточно места для копии. Для этого можно 
использовать функцию ОІ$К$РАСЕ(), которая возвращает число 
свободных байтов на активном диске. 

После копирования или в других случаях нередко требуется 
переименовать файл. Для этого используется команда 

КЕИАМЕ <имя файла > ТО < новое имя файла > 

в которой и старое, и новое имя файла должно включать 
расширение. Если файлы расположены на диске, отличном от 
текущего, то перед именем файла, как это уже неоднократно 
упоминалось, следует поместить идентификатор диска и маршрут 
по директориям. Новое имя файла не должно совпадать с 
именем существующего файла, расположенного в том же 
директории. При переименовании файла БД с полями Мето, 
файл .сІЬі следует переименовывать отдельно. Запрещается 
изменять имя открытого файла. 

Пример: 

КЕММЕ Ріо. ОВР ТО Зрізок.ОВР 

Перед копированием иногда целесообразно определить объем 
файла БД. Его можно вычислить (без полей Мето) как 
произведение длины записи на их количество. Для опреде¬ 
ления длины записи можно использовать функцию 
&ЕС512Е([ < ал нас > ]), а для определения числа записей - 
функцию ЛЕССОІІЫТ([ <алиас >]). Функция КЕССОУЫТ возвраща¬ 
ет число записей в текущем, или указанном алиасом файле БД. 
Если нет открытых файлов, то возвращается 0. Возвращенное 
число включает все записи файла БД, в том числе и помеченные 
для удаления, даже если установлены команды 5ЕТ РЕІ.ЕТЕО ОИ 
и $ЕТ РИТЕК. 

Пример: 

СОРУ РНЕ РК06.РК6 ТО С0РУРК06. РР6 

При выполнении операций импорта, экспорта, перезаписи и 
удаления файла надо быть внимательными. Особенно это 
касается удаления, так как после этой операции файл восстано¬ 
вить уже нельзя. Для предотвращения от несанкционированной 
перезаписи или удаления файла служит состояние 5ЕТ 5АРЕТѴ 
ОЫ (устанавливается по умолчанию), которое высвечивает при 
создании нового файла с уже существующим именем сообщение 
Рііе аігесіу ехі$і$ (файл уже существует) и предлагает на выбор 
меню с позициями: Оѵегжгііе (перезаписать) или СапсеІ 
(отменить). Если нельзя перезаписать этот файл, то после 
выбора позиции СапсеІ можно ввести имя нового файла, создав 
тем самым копию файла под другим именем. В состоянии $ЕТ 
5АРЕТѴ ОРР перезапись осуществляется автоматически без 
предупреждающего сообщения. При выполнении команды 2АР 
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в состоянии 5ЕТ 5АРЕТѴ ОИ также выводится сообщение, 
требующее подтверждения об удалении файла. 

Кроме копирования, новый файл можно создать слиянием 
полей из двух файлов. Эта операция выполняется командой 

ЮІИ ЛѴІТН <алиас> ТО <имя файла> 

РОК < условие > [РІЕЮЗ < список полей>] 

которая создает новый файл БД посредством слияния заданных 
полей (кроме Мето полей) двух открытых файлов БД: одного 
в текущей рабочей области, а второго в рабочей области, 
заданной алиасом (напомним, что по умолчанию алиас совпадает 
с именем файла БД). 

Опция РОК позволяет отобрать в новый файл записи из двух 
исходных файлов в соответствии с заданным условием, которое 
проверяется для каждой записи этих файлов следующим 
образом. Сначала проверяется условие для первой записи 
первого файла и для всех записей второго файла, и все 
удовлетворяющие этому условию пары записей (с заданными 
полями) включаются в новый файл. Затем этот процесс повторя¬ 
ется для второй записи и т.д. 

Заметим, что для больших файлов процесс их слияния может 
занять довольно много времени, а новый файл потребует много 
места на диске, если условие отбора достаточно широкое. Если 
в исходных файлах есть поля с одинаковыми именами, которые 
нужно включить в новый файл, то надо в списке перед ними 
указать алиас со стрелкой вправо (для неактивной рабочей 
области). Вместо указания списка полей можно предварительно 
установить команду ЗЕТ РІЕЮЗ. 

Пример: 

ІІ5Е Регзоп АИА5 В 

УЗЕ РІО 

МІИ ѴІТН В ТО ЗРІЗОК РОК Рат=В->Раш 

ЗЕТ РІЕЮЗ Раш, Иате, В->Агігез, В->6огогі, $итта 

ІІЗЕ ЗРІЗОК 

І_І5Т 5ШСШЕ 

Для того чтобы скопировать из файла БД, не все записи, а 
только часть и, кроме того, не все поля, а только заданные, 
используется команда 

СОРУ ТО <имя файла > 

[ТУРЕ <тип файла >] [< диапазон >] 

[РІЕЮЗ ссписок полей>] [\ѴНИ.Е <условие>] 
[РОК < условие >] 

которая копирует в новый файл записи, определяемые заданным 
диапазоном, условиями РОК и \УНІІ.Е и метками для удаления 
(если установлена команда ЗЕТ РЕ1.ЕТЕ0 ОИ). Копируемые поля 
определяются опцией РІЕЮЗ или командой ЗЕТ РІЕЮЗ ТО. 
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Выходной файл может быть типа сІВАЗЕ и не-сІВАЗЕ. В послед¬ 
нем случае требуется в опции ТѴРЕ задать тип внешнего файла. 
Поля Мето копируются только в том случае, если выходной 
файл является файлом сІВАЗЕ IV. При копировании во внешние 
файлы не проверяется совместимость типов и форматов данных. 
В качестве типов внешних файлов можно использовать те же 
типы, что и в команде АРРЕИй РВОМ. Файлы БД сІВАЗЕ IV с 
полями Мето нельзя открыть в сІВАЗЕ 111 + . Для этого их надо 
скопировать в новый файл, используя тип ОВМЕМОЗ. Копирова¬ 
ние файлов йВАЗЕ IV в файлы формата РР5 можно выполнить 
командой 

ЕХРОВТ ТО < имя файла > [ТУРЕ] РР5Д>ВА5Е ІІ/Р\Ѵ2/ВР0 
[РІЕЮ ссписок полей>] [<границы>] 

[РОВ < условие >] [УЖ НЕ < условие >] 

которая позволяет копировать файл БД, кроме того, и в файлы 
форматов ЭВАЗЕ II, Р№ и ВРй. Использование остальных опций 
описано в предыдущей команде СОРУ. 

Чтобы скопировать содержимое только поля Мето в другой 
файл, используется команда 

СОРУ МЕМО симя тето поля> ТО <имя файла > 
[АРРІТІѴЕ] 

которая копирует информацию из текущего поля Мето в 
текущую запись файла на диске (если не указано расширение, 
то подразумевается текстовый файл). Для копирования поля 
Мето из другой рабочей области перед его именем следует 
указать алиас рабочей области со стрелкой. Если имя поля 
содержится в списке, определенном командой ЗЕТ РІЕІ.03, то 
алиас указывать не требуется. Опция АйОІТІѴЕ позволяет 
добавить содержимое поля Мето в конец записи или файла 
(если выходным файлом служит текстовый файл). Если эта 
опция не используется, а выходной файл существует на диске, 
то содержимое поля Мето заменяет (перекрывает) данные в 
этом файле. 

Пример: 

СОРУ МЕМО АѵіоЫо ТО АѵІоТІІе АООІТІѴЕ 

Операцию, обратную команде АРРЕЫО РВОМ АВВАУ, 
выполняет команда 

СОРУ ТО АВВАУ <имя массива > [РІЕЮЗ <список полей >] 
[< границы >] [РОВ < условие >] 

[УЖ НЕ < условие >] 

которая копирует отобранные записи и содержимое заданных 
полей из файла БД в существующий массив. Поля записей 
копируются последовательно в колонки массива. Каждая запись 
становится строкой массива. Процесс копирования полей продол- 
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жается до тех пор, пока не исчерпаются поля или колонки 
массива. Если файл БД имеет больше полей, чем колонок в 
массиве, лишние поля не копируются. В противном случае 
лишние колонки массива остаются неизменными. Нельзя копиро¬ 
вать в массив поля Мето. В одномерный массив копируется 
одна запись. 

Пример: 

1)5Е По && Файл По.ОВР имеет 5 полей 

С01Ш РОЛ Р1о_ісі = 'АО001' ТО тспі 

йЕСІ-АКЕ Кессгсіз [шсгѵЬ,5] && Определение массива 

СОРУ ТО АККАѴ Кесогсіз РОК Ріо_іс1 = 'А000Г 

Во многих операциях по обработке файла встречалась опция 
РОК для отбора записей по заданному условию. Если одно такое 
условие требуется использовать во многих командах, то вместо 
опции РОК можно предварительно выполнить команду 

$ЕТ РИТЕК ТО [РНЕ <имя файла>/?] [<условие>] 

которая позволяет установить условие (фильтр) для отбора 
записей при выполнении многих команд обработки файла БД. 
Условие в этой команде представляет собой допустимое в СІВА5Е 
IV выражение, которое может состоять из элементарных условий 
(см. разд. 2.4), объединенных логическими операторами. 

Опция РНЕ дает возможность устанавливать в качестве 
фильтра файл запроса, созданный командой СКЕАТЕ/МОРІРѴ 
СШЕКѴ (см. раздел 3.3) или в режиме УЦ, управляемом меню. 
Если открыт каталог, то опция ? позволяет высветить список 
файлов запросов для активного файла БД. Файлы запросов, 
созданные в <ЗВА5Е III +, можно использовать в сіВАЗЕ IV, но 
их нельзя модифицировать. 

Для каждой рабочей области можно установить свой фильтр. 
Выключение фильтра выполняется командой 5ЕТ РИТЕК ТО без 
опций. Фильтр активизируется только после перемещения 
указателя записи файла БД, например командами ©О ТОР или 
5КІР!Г Фильтр применяется не только к командам, которые 
имеют опцию РОК, но и ко всем командам, в которых использу¬ 
ются открытые файлы БД (например, команды подготовки к 
печати данных из файла БД, команды вычислений агрегированных 
значений полей и т.д.). 

Пример: 

іі$е по 

$ЕТ РИТЕК ТО 016 = '01' 

60 ТОР 

И$Т Раш,Маше 

$ЕТ РИТЕК ТО 

После завершения операций с файлами БД их следует 
закрыть командой СЮ5Е АИ/АІЛЕКЫ АТЕД) АТАВ А5Е5/РОКМАТ/ 
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ІМОЕХ/РКОСЕОІІКЕ, которая позволяет закрыть все открытые 
файлы или файлы определенного типа. 

Опция АІ.І. закрывает все файлы и устанавливает в качестве 
текущей рабочую область 1. При этом если открыт каталог (для 
него предусмотрена рабочая область 10), то его рабочая область 
не закрывается. Для закрытия файлов определенного типа 
используются опции: АІЛЕКИАТЕ - альтернативные файлы, 
записанные на диск; РАТАВА5Е5 - файлы БД, индексные файлы, 
файлы полей Мето и экранных форм, связанные с файлами БД; 
РОКМАТ - файлы экранных форм; ІЫРЕХ - индексные файлы; 
РКОСЕОІРКЕ - программные файлы и процедуры. Для закрытия 
конкретного файла БД и связанных с ним файлов используется 
команда №Е. 

Выше рассматривалась команда 2АР удаления записей в 
файле БД. После такого удаления структура файла сохраняется 
и можно вновь вводить данные. Если требуется полностью 
уничтожить файл, то это можно сделать командой 

ЕКА5Е <имя файла>/? или РЕ1.ЕТЕ РНЕ <имя файла >/? 

При этом удаляемый файл должен быть закрыт, а имя файла 
должно включать расширение. Если файл удаляется не на 
текущем диске или в другом директории, то ему должны 
предшествовать имя диска и маршрут по директориям. При 
удалении файла БД с полями Мето файл этих полей следует 
удалять отдельно. Это же относится к связанному множествен¬ 
ному индексному файлу. В отличие от аналогичной команды 005 
в данной команде не разрешается использовать шаблон имени 
файла. 

Перед выполнением любой работы на ПК целесообразно 
установить диск, который будет использоваться по умолчанию 
для всех операций (записи новых, модифицированных файлов 
БД, связанных и вспомогательных файлов и т.д.). Для этого 
служит команда 5ЕТ ОЕРАШЛ ТО <диск>[:]. При этом устанав¬ 
ливается директорий, назначение которого было последним для 
этого диска. Например, если был осуществлен переход на диск 
А с директория \ВА$А диска С, то после возвращения обратно 
на диск С командой $ЕТ ОЕРАШЛ будет установлен директорий 
\ВА$А. Команда $ЕТ ОЕРАШЛ не проверяет, существует ли 
назначаемый диск, и не меняет диск, на который осуществляется 
переход после выхода из сІВАЗЕ IV. 

При разработке программ для работы с файлами весьма 
полезной является также команда $ЕТ РАТН ТО [<список 
маршрутов >], которая позволяет установить список маршрутов 
по директориям дисков, используемых для поиска требуемого 
файла, если он не найден в текущем директории. 

Следует отметить, что в СІВА5Е IV не используются маршру¬ 
ты, установленные в ЭОЗ командой раіЬ, так же как и в РОЗ не 
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используются маршруты, установленные в <ЗВА5Е IV. Точно так 
же маршруты, установленные в УЦ, не используются в команд¬ 
ном режиме и при выполнении программ, как и маршруты, 
установленные командой $ЕТ РАТН в программах не используют¬ 
ся в УЦ. Команда $ЕТ РАТН ТО без параметров восстанавливает 
директорий, установленный по умолчанию. Этим директорием 
является директорий, откуда стартовал сІВА$Е IV, директорий, 
установленный командой 005 сНсІіг или командой сІВАБЕ IV $ЕТ 
0ЕРАШ.Т. 

Для вывода имен файлов в директориях и информации о 
файлах на диске используется команда 

ОІК/ОІКЕСТОКѴ [[ОИ] сдиск: >] Ш-'КЕ] 

[ < маршрут > ][ < шаблон > ] 

Если не задано имя файла или его шаблон, то выводится 
информация только о файлах БД. Если не указан диск и 
маршрут, то выводится информация в текущем директории на 
текущем диске. Для файлов БД выводятся их имена, число 
записей, дата последнего обновления, размер в байтах, общее 
число высвеченных имен файлов и емкость оставшейся свободной 
памяти на диске. Для других типов файлов высвечивается только 
имя. 

Следует отметить, что директорий может не отражать 
последних изменений, если установлена команда 5ЕТ АІІТОБАѴЕ 
ОИ, до тех пор, пока файл не будет закрыт. Для вывода имен 
всех типов файлов следует использовать шаблон *.*. 


3.3. ПОИСК И ОТБОР ДАННЫХ 

Описанные в разд. 3.2 команды позволяют выполнить все 
операции по созданию файлов БД, вводу в них данных, последу¬ 
ющего обновления и удаления записей, а также просмотра 
записей. Для передвижения по файлу предусмотрены позиции 
меню полноэкранных команд типа ВКО>Ѵ$Е и ЕОІТ, а также 
команды пошагового перемещения и перемещения на запись с 
заданным номером. Однако нередко требуется найти запись не 
по ее положению в файле БД, а по содержанию полей. Такой 
вид поиска предусмотрен, например, в меню команды ВКО>Ѵ$Е. 

В настоящем разделе будут рассмотрены специальные 
команды для организации поиска и отбора записей из файлов 
БД. Способ поиска по содержанию полей зависит от того, 
созданы ли индексные файлы по этим полям или их комбинаци¬ 
ям. Для поиска по неиндексированным полям используется 
команда ^ 

ЮСАТЕ [РОК] <уеловие>[<диапазон>] 

[ѴѴННЕ <условие>] 
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Эта команда выполняет в активном файле БД поиск первой 
записи, удовлетворяющей условию, заданному опцией РОК. 
Опции <диапазон> и >ѴНІІ-Е определяют диапазон и условие 
начала и конца просмотра записей. Если эти опции не заданы, то 
поиск начинается с первой записи. При успешном поиске 
указатель записи устанавливается на запись, удовлетворяющую 
заданному условию. Для определения успешности поиска можно 
использовать функцию РОІЖОО, которая возвращает в этом 
случае логическое значение .Т. В случае установки команды 5ЕТ 
ТАІ_К ОИ высвечивается номер найденной записи. Если в 
заданном диапазоне или в целом файле требуемая запись не 
найдена, то высвечивается сообщение ЕпсІ о( І_ОСАТЕ зсоре 
(конец поиска в заданном диапазоне) и указатель записи 
перемещается в конец файла (за последнюю запись). В этом 
случае функция ЕОР() принимает значение .Т., а РОІ)ИО() = .Р. 
Для поиска следующей записи, удовлетворяющей заданному 
условию, нужно вслед за командой І.ОСАТЕ выполнить команду 
СОИТІИІІЕ. В любой из рабочих областей можно организовать 
автономный поиск. Для этого выбирается другая рабочая область 
и выполняется команда ЮСАТЕ (и, если нужно, соитіииЕ). 
После возвращения в исходную рабочую область указатель 
записи в ней находится в том же положении, какое было до 
перехода, и можно продолжать прерванный поиск. 

Для поиска по индексированным полям используются 
команды 5ЕЕК и РІИй. Команда 5ЕЕК <выражение > выполняет 
поиск первой записи файла БД с заданным значением индексиро¬ 
ванного поля. При этом соответствующий индекс должен быть 
установлен в качестве главного (управляющего) индекса. 

Заданное поисковое значение может быть результатом 
раскрытия любого, разрешенного в СІВА5Е IV выражения. Обычно 
это выражение записывается в переменную. Типы данных 
поискового значения и индексного выражения должны совпадать. 
В качестве поискового значения можно задавать подстроку 
(часть строки) символьного поля, но начиная только с первой 
позиции. Причем в этом случае должно быть установлено 
состояние $ЕТ ЕХАСТ ОРР (задается по умолчанию). Это 
состояние обеспечивает сравнение строк разной длины. Сравне¬ 
ние двух строк выполняется побуквенно, начиная с первой 
позиции и до конца правой из двух сравниваемых строк. Если 
эти символы совпадают, то результат сравнения положительный 
(возвращается логическое значение .Т. этой операции). В данном 
случае правой является строка заданного значения в команде 
§ЕЕК, а левой - значение из соответствующего поля файла БД. 
Например, если требуется найти значение "Петров" поля РАМ 
(фамилия) файла БД, то для поиска можно использовать часть 
этого значения, начиная с первой позиции - "Пет", если, конечно, 
это сокращение однозначно идентифицирует данную фамилию. 
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В состоянии 5ЕТ ЕХАСТ ОИ процесс сравнения строк 
выполняется аналогично, но до конца самой длинной из строк. 
В состоянии $ЕТ ОЕЬЕТЕй ОЫ и при установленной команде БЕТ 
РII. ТЕР. для поиска отбираются отфильтрованные и непомеченные 
для удаления записи. Если запись не найдена, то высвечивается 
сообщение РіпсІ по! $иссе$$М (поиск неуспешен) и указатель 
записи перемещается в конец файла БД (ЕОР() = -Т.), если 
установлена команда БЕТ ИЕАР ОРР. При успешном выполнении 
команды БЕЕК функция РОІЖО() принимает значение .Т. и 
указатель записи остается на найденной записи. Для подавления 
вывода сообщения можно использовать установку состояния БЕТ 
ТА1.К ОРР. Состояние $ЕТ ТАІ.К ОН позволяет выводить на экран 
информацию при выполнении коа анд обработки записей, 
включая: номер записи, содержимое переменных, результаты 
выполнения команд АРРЕЫР РВОМ, СОРѴ, РАСК, 5ТОРЕ и др. 
Эта команда часто используется в программах для визуального 
контроля выполнения команд и обработки записей. 

Для того чтобы при неуспешном п^'-ске найти запись, 
наиболее близкую по индексному выражению, используется 
состояние $ЕТ ИЕАК ОН. В этом случае указатель устанавливается 
на запись, значение индексного выражения коте оой следует 
непосредственно за искомым значением. 

Пример: 

УЗЕ 2АКІІРК I ІМЕХ Эаігакир 

5ЕЕК СТ00( '11/03/85') 

Команда РІЫЭ < литеральная строка > аналогична команде 
БЕЕК и также выполняет поиск первой записи в индексированном 
файле БД с заданным значением индекса при установленном 
соответствующем главном индексе. Отличие состоит в том, что 
в качестве поискового значения в команде РІЫР используется не 
выражение, а литеральная строка. Для того чтобы задать 
ведущие пробелы в литеральной строке поискового значения, 
следует заключить эти пробелы вместе с литеральной строкой в 
кавычки, например РІЫЭ " Введение". Если литеральная строка 
содержится в переменной, то для задания поискового значения 
в таком виде следует использовать функцию макроподстановки 
6с, например РІИй &Уаг1, где Ѵагі - имя переменной. В том 
случае, когда в содержимое переменной должна входить 
литеральная строка с ведущими пробелами, нужно заключить в 
кавычки имя переменной вместе с символом функции макропод¬ 
становки, например "&Ѵаг1". 

Если в поисковое значение литеральной строки входят 
кавычки, то тогда эту строку надо заключить в другой раздели¬ 
тель, например в квадратные скобки: РІИР ["Зенит"]. Действие 
состояний, устанавливаемых командами БЕТ ЕХАСТ, БЕТ РЕІ.ЕТЕО, 
БЕТ РІІ.ТЕК, БЕТ ЫЕАВ, и возвращаемые функциями РОІІЫРО и 
ЕОР() значения полностью аналогичны команде $ЕЕК. 
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Как уже упоминалось выше, для определения успешности 
поиска после команды $ЕЕК часто используется функция 
РОЦИйО. функция $ЕЕК(< выражение>[,<алиас>]) об'единяет 
действие команды 5ЕЕК и функции РОІЖО() и тем самым 
позволяет сократить запись такой операции. Эта функция 
возвращает логическое значение .Т. (.Р.), если найдена (не 
найдена) запись с заданным значением индексного выражения в 
текущей или заданной алиасом рабочей области. Обычно 
функция $ЕЕК() используется в командах, определяющих 
ветвление процесса выполнения операций. 

Пример: 

а= м Иванов" 

ІР ЗЕЕК(а) 
йО Ргосі 
ЕШР 

Нередко после поиска требуемого значения поля нужно 
вывести значение другого поля этой же записи. Для выполнения 
такой операции можно использовать функцию К.ООКІІР( < возвра¬ 
щаемое поле>, < поисковое выражение >, < просматриваемое 

поле>), осуществляющую поиск записи, в которой значение 
просматриваемого поля совпадает с поисковым выражением, и 
возвращающую значение из заданного поля файла БД. Возвраща¬ 
емое поле может быть задано в виде любого допустимого 
выражения <ЗВА5Е IV. 

Пример: 

ІІ$Е Ріпапз 

? ЮОКУР (Рат, *'200 м ,0к1агі) && Выводит фамилию сотрудника 
* с окладом 200 рублей 

В число операторов отношений, которые формируют 
элементарные условия для поиска и отбора записей, входят: 
"больше чем","меньше чем","равно", "не равно", "больше или 
равно", "меньше или равно", "содержит" (см. разд. 3.1). 

Кроме указанных, язык сІВАЗЕ IV позволяет сформировать 
дополнительные операторы отношений, например "звукоподобно" 
и "подобно" (І.ІКЕ). Основой оператора "звукоподобно" 
является функция $ОІІИОЕХ( < выр.С >), которая возвращает 
звукоподобный код слова. Этот код, состоящий из четырех 
символов, вычисляется по следующему алгоритму: 

1. Оставляется первая буква заданного символьного выраже¬ 
ния. 

2. Выбрасываются буквы аеЬіои^уиз всех позиций, 
кроме первой. 

3. Оставшимся буквам присваивается число: 

Ь I р ѵ = 1 
с д і к я $ х 2 = 2 
4 1=3 
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5 


I = 4 

т п = 

г = 6 

4. Если две или более соседние буквы имеют одно и то же 

число, оно отбрасывается, за исключением первой буквы. 

5. Конструируется код по форме "'буква цифра цифра 

цифра". Вместо цифр добавляются нули, если цифр меньше 

трех. Удаляются цифры справа, если их больше трех. 

6. Формирование кода прекращается на первом небук¬ 
венном символе. 

7. Пропускаются ведущие пробелы. 

8 . Возвращается код "0000", если первый символ, не 
являющийся пробелом, будет небуквенным. 

Сформированный код может быть использован в качестве 
признака для поиска звукоподобных совпадений английских слов. 
Функция ОІРРЕКЕИСЕ( <выр.С>, <выр.С> ) определяет различие 
между двумя символьными строками посредством преобразова¬ 
ния их в коды функции $О1!Ы0ЕХ() и сравнения полученных 
значений. Эта функция возвращает целое число в диапазоне от 
0 до 4. Максимальное сходство сравниваемых символьных строк 
- 4, а минимальное, когда нет общих букв - 0, сходство в одной 
букве - 1. 

Пример: 

ІІЗЕ Гіпапз 

5САИ 

ІР (ОІРРЕКЕИСЕ (Раш, "РеІгоЕР") = 1 
00 Ргос2 
ЕМІР 

ЕМОЗСАН 

Функция ЫКЕ( < образец >, < выр.С > ), которая служит 
основой оператора "подобно", сравнивает строку, заданную в 
образце, с символьной строкой (из поля файла БД, переменной 
и т.д.) и возвращает .Т., если образец содержится в символьной 
строке. В образце допускается использование знаков замещения 
* и ?. Напомним, что первый из них замещает любое количество 
символов, а второй только один символ. Эти знаки не различают 
строчные и прописные буквы, тогда как функция ЫКЕ их 
различает. 

Чтобы избежать различения строчных и прописных букв, 
можно символьную строку преобразовать к прописным буквам 
функцией ІІРРЕК( < выр.С >), а в образце задать только 
прописные буквы (см. разд. 3.7). 

Пример: 

? ИКЕ("0ВА$Е*",иРРЕК("с1ВА$Е IV м )) && возвращает .Т. 

При задании поискового выражения в виде содержимого 
символьной переменной, особенно в случае ввода целого 
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условия или его части с клавиатуры, могут быть ошибки, в 
результате чего выражение изменит свой тип, например, из 
логического в другой тип. 

Для контроля типа выражения можно использовать функцию 
ТѴРЕ(<выр.С>), которая определяет тип символьного выраже¬ 
ния и возвращает следующие прописные буквы, обозначающие 
его тип: 

С - символьная строка; 

N - число; 

I. - логическое выражение; 

М - поле Мето; 

О - дата; 

Р - число с плавающей запятой; 

II - неопределенное. 


3.4. ВВОД И ВЫВОД ИНФОРМАЦИИ НА ЭКРАН 

В предыдущем разделе уже рассматривались стандартные 
экранные формы ввода и вывода информации - Вготе и Есііі. 
Однако эти формы не всегда удобны для пользователя. В 
прикладных задачах, предназначенных для конечного пользовате¬ 
ля, желательно улучшить оформление экрана и обеспечить 
максимум удобства в работе. Для этого поля файлов БД 
размещаются более наглядно на экране и сопровождаются 
поясняющей и справочной информацией, организуется система 
проверки вводимой с клавиатуры информации с целью избежа¬ 
ния ошибок и т.д. 

Основной командой, предназначенной для создания нестан¬ 
дартных экранных форм ввода и вывода информации, является 

@ < строка >, < колонка > 

[5АѴ <выр.> 

[РІСТШІЕ <выр.С>] 

[РІІИСТІОИ ссписок функций>]] 

[СЕТ < переменная > 

[[ОРЕИ] \ѴІИОО\Ѵ <имя окна>] [РІСТШІЕ <выр.С>] 
[РІІИСТІОИ <список функций >] 

[РАИСЕ [<нижний>] [, сверхний > ]] 

[УАИЭ <условие> [ЕККОК <выр.С>]] 

[УЖЕЙ < условие >] [ЭЕРАШТ < выражение >] 
[МЕ55АСЕ свыр.О]] 

[СОЮК [< стандартная область экрана >] 

[,< нестандартная область экрана >]] 

Эта команда позволяет выводить или вводить информацию 
в заданном формате в указанные места экрана. Кроме того, с 
помощью опции $АѴ этой команды можно выводить данные на 
принтер или в файл на диске. Для того чтобы установить вывод 
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информации с помощью данной команды на экран, принтер или 
в текстовый файл 005, используется команда 5ЕТ ЬЕѴІСЕ ТО 
ЗСКЕЕИ/ргшІег/гіІе < имя файла > . 

Строка и колонка после глагола команды позволяет задать 
координаты начала выводимой (вводимой) информации в виде 
числовых выражений. Значение < строка > может быть в 
диапазоне от 0 до максимального числа строк экрана, значение 
<колонка> - в диапазоне от 0 до 79. При выводе на принтер 
значение <строка> может находиться в интервале от 0 до 
32767, а значение < колонка > - в интервале от 0 до 255. Если 
при этом координаты последующей команды @...$АѴ меньше 
предыдущей, то выполняется перевод листа. На некоторых 
принтерах эта команда не печатает до тех пор, пока не освобож¬ 
дается его буфер командой ЕІЕСТ или выводом пустой строки. 
Если активизировано окно, то координаты <строка>,<колонка> 
отсчитываются от его левого верхнего угла. Следует отметить, 
что если установлено состояние $ЕТ $ТАТи$ ОИ (по умолчанию 
в сШАЗЕ IV устанавливается 5ЕТ 5ТАТІІ5 ОРР, хотя в файле 
СоггНд.сІЬ это состояние при запуске системы установлено как 
ОЫ), то 22-я строка экрана резервируется для информации о 
состоянии системы. На ней высвечивается имя выполняемой 
команды, имя активного файла БД, номер текущей записи и их 
общее число, а также информация о режимах клавиатуры, если 
еще и установлено состояние 5ЕТ 5СОКЕВОАКО ОИ. В состав 
этой информации входят: символ ОеІ, указывающий на то, что 
текущая запись помечена для удаления; ІП5 - установлен режим 
раздвижки текста при вводе с клавиатуры; Сар$ и Ыит - 
установлены режимы клавиатуры, соответствующие этим клави¬ 
шам. Если одновременно установлены состояния $ЕТ 5ТАТІІ5 ОРР 
и 5ЕТ ЗСОКЕВОА&О ОИ, то эта информация выводится на 
нулевую (самую верхнюю) строку экрана. Для подавления 
вывода информации о состоянии :истемы следует установить 
состояния $ЕТ $ТАТи$ ОРР и $ЕТ 5СОКЕВОАМ) ОРР. В ЭТОМ 
случае нулевую и 22-ю строки экрана можно использовать для 
размещения элементов создаваемой экранной формы. Если в 
экранной форме выводятся вычисляемые поля, то при изменении 
содержимого полей, которые влияют на результаты вычислений, 
эти вычисления выполняются, а результаты можно высветить при 
нажатии клавиш Рді Ір и РдОп. Команда @ <строка> г <колонка> 
без опций очищает заданную строку, начиная с указанной 
колонки. Опция 5АѴ выводит информацию, которую не требуется 
изменять. Опция СЕТ выводит и позволяет обновлять и редакти¬ 
ровать данные, содержащиеся в полях, переменных или массивах. 

Собственно обновление данных в переменных СЕТ 
(здесь и ниже под словом переменная подразумеваются также 
поля файла БД и элементы массива) выполняется командой 
КЕаО, которую следует поместить после данной команды. Эта 
команда активизирует переменные и вводит в них значения, 
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находящиеся на экране. После выполнения команды КЕАР 
экранные значения переменных СЕТ удаляются и при повторном 
открытии формы не высвечиваются. Если использовать команду 
КЕАР БАѴЕ, то экранные значения переменных СЕТ сохраняются 
и при повторном открытии экранной формы высвечиваются. 
Опция СОІ.ОК определяет цвета, используемые для высвечивания 
переменных 5АѴ и СЕТ. Участки экрана, на которых высвечивают¬ 
ся переменные БАѴ и СЕТ относятся соответственно к стандарт¬ 
ной и не стандартной области экрана. Коды цвета определяются 
так же, как и в команде БЕТ СОЮ& (см. разд. 3.2). Опция 
РЕРАШ.Т используется для установки в переменную ОЕТ значения 
по умолчанию, которое должно соответствовать типу этой 
переменной. Это значение появляется после высвечивания 
экранной формы. Его можно принять клавишей Епіег без 
изменения или после редакции. Выражение в этой опции 
вычисляется только при добавлении записей в файл БД. Следует 
отметить, что значение по умолчанию может быть перекрыто 
данными из предыдущей записи, при установленном состоянии 
БЕТ САРКУ ОИ. 

Опция ЕККОК <выр.С> используется для высвечивания 
сообщения пользователя, когда не выполняется заданное в опции 
ѴАІ.Ю условие. Это сообщение перекрывает стандартное 
сообщение сІВАЗЕ IV Есіігіпд сопсШіоп поі заіізііесі 
(условие редактирования не выполнено), которое также 
высвечивается в этом случае. Опция МЕББАСЕ <выр.С> 
высвечивает сообщение, которое появляется после перемещения 
курсора в поле ОЕТ при выполнении команды КЕАО. Если 
установлено состояние БЕТ БТАТІІБ ОЫ, то сообщение появляется 
в центре нижней строки экрана, иначе оно не появляется. Эта 
опция временно перекрывает сообщение, выводимое командой 
БЕТ МЕББАОЕ. Опция \ѴЖРО^ <имя окна > используется при 
установке окна для редактирования содержимого поля Мето 
переменной ОЕТ. Для открытия окна необходимо установить 
курсор в поле Мето и нажать клавиши СМ-Ноте. Клавиши 
СігІ-ЕпсІ закрывают окно. Как уже ранее указывалось, если 
маркер поля Мето высвечивается прописными буквами, то оно 
содержит информацию, если строчными, то не содержит. При 
отсутствии опции >УІМРО>У поле Мето выводится на полный 
экран. Для ввода и обновления текста в поле Мето используется 
текстовый редактор сІВАЗЕ IV. Можно также применять любой 
другой редактор, для чего нужно записать его имя в качестве 
значения параметра \УР в файле Сопгід.сІЬ. 

Опция ОРЕМ \ѴтОО\Ѵ <имя окна> позволяет автоматичес¬ 
ки открыть окно для поля Мето. Опция РІСТІР&Е используется 
для ограничения типа вводимых данных или для форматирования 
выводимых данных посредством использования знаков шаблона 
и может включать функцию поля, которая записывается в виде 
символа (§) и следующей за ним условной буквы, обозначающей 
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действие функции. Функция и шаблон поля вместе определяют 
ввод и вывод символов данных (более подробно см. разд. 2.5). 

Отметим, что знаки шаблона и функции должны разделяться 
пробелами. Аргументом этой опции может быть любое символь¬ 
ное выражение, хотя обычно оно представляется в виде строки 
символов в кавычках. Если в качестве аргумента используется 
символьная переменная, то ее нужно заключать в круглые 
скобки. Функции поля можно вводить отдельно в виде списка в 
опции РІЖСТІОК В этом списке перечисляются (через запятую) 
только условные буквы без знака @. В табл. 3.3 и 3.4 приводит¬ 
ся список функций и знаков шаблона. 

Функции уч , $, (, С, \~, X и 1 используются с числовыми 
данными типа N и Р (причем (, С и X только для вывода, т.е. 
с опцией $АѴ), О и Е с данными фіпа даты, а А, М, К и $<п> 
с символьными данными. Можно создавать новые функции поля 
посредством комбинирования уже имеющихся. Например, 
функция ХС выводит аббревиатуру РВ после отрицательных 
чисел и ск после положительных. Нельзя совместно использовать 
взаимоисключающие функции, например, Р и Е. 


Таблица 3.3. Список функций поля 


Функция 

Описание 

! 

Допускает любой символ и преобразует буквы 
в прописные 

Выводит числа в формате с плавающей точкой 

$ 

Выводит числа со знаком валюты 

( 

Заключает отрицательные числа в скобки 

А 

Допускает только алфавитные символы 

В 

Выравнивает текст по левому краю поля 

С 

Выводит аббревиатуру СК(кредит) после 
положительного числа 

й 

Устанавливает текущий формат для даты 

Е 

Устанавливает европейский формат для даты 

I 

Центрирует текст внутри поля 

и 

Выравнивает текст по правому краю поля 

і 

Выводит ведущие нули чисел 

и 

Позволяет выбирать альтернативные значения 
для переменной 6ЕТ 

к 

Высвечивает литеральные символы в поле на 
экране, но не вводит их в поле файла БД 

5<п> 

Определяет ширину выводимого поля 
п символами и позволяет прокручивать 
внутри него информацию 

Т 

Удаляет ведущие и хвостовые пробелы из 
поля 

X 

Выводит сокращение ОВ (дебет) после 
отрицательного числа 

1 

Выводит нулевое значение числа как строку 
пробелов 
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Таблица 3.4. Перечень знаков шаблона 


Символ 

Описание 

і 

Преобразует буквы в прописные 

# 

Выводит только цифры, пробелы и знаки чисел 

$ 

Выводит символ валюты, установленный 


командой $ЕТ СІІККЕЮ, вместо ведущих 


нулей 

* 

Выводит знаки * вместо ведущих нулей 


Отмечает каждые три порядка слева от 


десятичной точки 

. 

Определяет положение десятичной точки 

9 

Допускает вывод только цифр для символьных 


данных. Для числовых данных выводит цифры 


и знаки чисел 

А 

Допускает вывод только букв 

Ь 

Допускает вывод только логических данных 

N 

Допускает вывод букв и цифр 

X 

Допускает вывод любого символа 

У 

Выводит только логические значения У,у,И,п. 


Преобразует у,п в прописные 


Функция $ выводит символ валюты до или после значения 
переменной СЕТ. Символ валюты размером до 9 символов и его 
размещение справа или слева от числа устанавливаются команда¬ 
ми 5ЕТ СІЛІІІЕНСѴ ТО <выр. С> и $ЕТ СІЛ*КЕМСѴ І.ЕРТ/&ІСНТ 

Для просмотра длинного значения символьной строки в 
выводимом на экране более коротком поле используется 
функция $<п>, где п - количество позиций этого поля. Число 
п не должно отделяться от символа 5 пробелами. Этот просмотр 
выполняется навигационными клавишами Вправо, Влево, Ноте и 
ЕпсІ. Одновременно с ним можно редактировать символьную 
строку. Функция М позволяет для переменной СЕТ выбирать 
клавишей Пробел заданные в списке альтернативные значения (в 
виде литералов, разделяемых запятой), например РІЖСТІОЫ 
"М < список значений >". 

Можно также выбирать эти значения, нажимая на клавиатуре 
их первую букву. Функции В,І и } выравнивают значения полей. 
По умолчанию строки выравниваются влево, а числа вправо. 

Знаки шаблона !, #, 9, А, N и X используются в опциях 5АѴ 
и СЕТ. Все эти знаки, кроме !, не разрешают ввод недопустимых 
символов, но позволяют их высвечивать. Следует напомнить, что 
при выводе чисел в состав шаблона нужно учитывать знаки для 
десятичной точки и знака числа (если требуется). Если в 
качестве знака шаблона используется знак, отличный от 
приведенных в таблице, то этот знак высвечивается в поле 
переменной на экране и вводится в нее (для переменной СЕТ). 
Если вместе с шаблоном используется функция к (для символь¬ 
ных переменных), то не предусмотренные в шаблоне знаки 
высвечиваются в поле, но не вводятся в переменную. 
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Опция КАЫСЕ используется для определения нижних и 
верхних границ вводимых значений символьных и числовых 
данных и данных типа даты. Можно вместо двух указывать 
только одну из границ, для чего нужно поставить запятую до 
или после значения границы. При наборе значения, выходящего 
за рамки указанных границ, в строке сообщений при состоянии 
5ЕТ 5ТАТІІ5 ОИ высвечивается предупреждение в виде заданных 
границ: КАЫСЕ і$ <т> іо <п> - двусторонние границы, 

І.ожегЬоипсІ і$ <п> - правая граница, Цррег Ьоипсі і$ <т> - 
левая граница. Если установлено состояние $ЕТ 5ТАТІІ5 ОРР, то 
эти границы высвечиваются на нулевой строке. Ввод неисправлен¬ 
ного значения можно выполнить клавишей Епіег. 

Опция ѴАІ.Ю устанавливает условие, которое должно быть 
выполнено перед тем, как данные вводятся в переменную ОЕТ. 
Если условие не выполнено, высвечивается сообщение Есііііпд 
сопсШіоп поі $аіІ5ІіесІ (условие редактирования не выполнено) 
или же сообщение, установленное опцией ЕККОК. Нажатие 
клавиши Епіег отменяет проверку этого условия. В качестве 
условия можно, например, записать вызов функции, определен¬ 
ной пользователем, если эта функция возвращает логическое 
значение, а также и вызов процедуры. 

Предыдущая опция проверяет условия ввода данных в 
переменную, тогда как опция >ѴНЕЫ позволяет задать условия 
для входа курсора в переменную СЕТ. Если в результате 
проверки этого условия возвращается логическое значение .Р., то 
курсор пропускает это поле и перемещается в следующее. В 
случае возврата .Т. курсор остается в поле и разрешается 
вводить в него данные. 

Перехват и обработку любой ошибочной ситуации при 
выполнении полноэкранных операций по вводу информации, 
включая ввод данных, не соответствующих типу поля, данных 
вне заданного диапазона и т.д., можно также выполнить 
посредством установки состояния ОЫ КЕАРЕККОК [<команда>], 
которое активизирует команду, программу или процедуру после 
возникновения ошибки. Команда ОЫ КЕАРЕККОК без аргумента 
отключает состояние перехвата ошибки. В этой команде запреща¬ 
ется использование ряда команд (тех, что и при построении 
функций пользователя - см. разд. 3.6). 

Разрабатываемая экранная форма может размещаться на 
нескольких страницах экрана (до 32). Передвижение по ним 
осуществляется клавишами РдРп и РдІІр Для организации 
многостраничной экранной формы надо по завершении каждой 
страницы поставить команду КЕАЭ. Для того чтобы использовать 
такую экранную форму, нужно предварительно записать ее в 
файл экранных форм с расширением .(ті. Открытие этой формы 
выполняется командой $ЕТ РОКМАТ ТО <имя Аті файла >. 
Экранная форма, открытая данной командой, используется вместо 
стандартного экрана в полноэкранных командах ЕРІТ и АРРЕИО 
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Для создания экранной формы можно также использовать 
команду СКЕ АТЕ/МООI РѴ 5СКЕЕЫ или окно Еогтз в УЦ (см. 
разд. 2.5). 

Пример: 

ІІЗЕ РІО 
С1.ЕАК 

0 10,5 $АѴ ТКІМ(РАМ)+" "+НАМЕ 

В этом примере выводится на экран через пробел поле 
фамилии (РАМ) и имени (ЫАМЕ) первой записи файла БД РІО 
в 10-й строке с 5-й позиции с удалением ведущих пробелов из 
поля РАМ. 

Пример: 
с!ау=" " 

0 1,1 ЗАѴ "Выбрать день недели” 6ЕТ сіау ; 

РІСТІЛІЕ ”0М Пон,Втр,Срд,Чтв,Птн,Суб,Век”; 

МЕ55А6Е "Для выбора дня недели нажмите клавишу; 

<Пробел>, а для ввода - <Еп1ег>" 

КЕАй 

В первой строке предыдущего примера на экран с первой 
позиции выводится сообщение "Выбрать день недели". Выбор 
значения переменной сіау осуществляется с помощью функции 
@М нажатием клавиши Пробел. Ввод выбранного значения 
выполняется Епіег 

Пример: 

5Т0КЕ 5РАСЕ (25) ТО тпате 

0 10,10 ЗАѴ "Введите имя: " 6ЕТ шпате 

РЕАО 

Для обеспечения пользователю удобства работы с экранной 
формой часто кроме пояснительных надписей на самом экране 
требуется организовать автоматический вызов на экран спра¬ 
вочной информации по текущему обрабатываемому полю 
(контекстно-чувствительная справка). Чтобы организовать такую 
справочную систему в программе, нужно знать, на каком поле 
в данный момент находится курсор. Это можно сделать с 
помощью функции ѴАККЕАО(), которая возвращает имя поля 
или переменной, обрабатываемой в текущий момент. Ниже 
приводится процедура для организации контекстно-чувствительной 
справки, которая выводится клавишей Р1 в заданное окно на 
экране. 

0И КЕѴ Р1 00 Зргаѵка 
0 10,10 ЗАѴ "Склад N 1” 6ЕТ Зкіасіі 
0 12,10 ЗАѴ "Склад N 2" 6ЕТ Зк1асі2 
КЕА0 

РК0СЕ01ЖЕ Зргаѵка 

с 1 г = ІИКЕѴ() && Очистка буфера клавиатуры 
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АСТІѴАТЕ УІЫООЫ Ѵіпзрг 
йО САЗЕ 

САЗЕ = ѴАККЕАО() = "$к1асі1" 

? "Описание профиля склада N 1" 

САЗЕ = ѴАККЕАРО = "5к1асі2" 

? "Описание профиля склада N Г* 

ЕИ0СА5Е 

? ІИКЕУ(О) && Удержание экрана 

ОЕАСТІѴАТЕ Уіпзрг 

КЕтикы 

Здесь для перехвата нажатой клавиши Р1 используется 
команда 

ОЫ ЕККОК < команда > /Е5САРЕ < команда > 

/КЕУ [ІАВЕІ<имя клавиши >] [< команда >] 

Эта команда устанавливает состояние ОИ перехвата ошибки 
(опция ЕККОК) при выполнении команд, обнаружении нажатия 
клавиши Езс (опция Е5САРЕ) или любой клавиши (опция 
КЕѴ без ключевого слова І.АВЕІ.), а также заданной клавиши или 
комбинации клавиш (с ключевым словом І.АВЕІ.). После 
обнаружения состояние ОИ выполняется указанная команда, 
вызывается функция, определенная пользователем, или проце¬ 
дура. Следует отметить, что функция или процедура должны 
быть предварительно откомпилирована, так как при их вызове 
компиляция не производится. Состояние ОЫ отменяется командой 
ОЫ ЕККОК/Е5САРЕ/КЕѴ без указания выполняемой команды или 
после выхода из сІВАЗЕ IV. Команда ОИ Е$САРЕ не работает, 
если установлено состояние 5ЕТ Е5САРЕ ОРР. 

После обнаружения состояния ОИ и выполнения заданной 
команды это состояние временно отключается до завершения 
выполнения команды или процедуры. Однако внутри процедуры 
можно установить новое состояние ОИ и, таким образом, 
образовать вложенные состояния ОИ. Если одновременно 
установлены все состояния, предусмотренные данной командой, 
то их обнаружение выполняется в следующей последователь¬ 
ности: ОН ЕМОК, ОЫ Е5САРЕ и ОЫ КЕѴ Если, например, ОИ 
КЕѴ и ОН Е5САРЕ установлены одновременно, нажатие клавиши 
Е$с вызывает исполнение команды, указанной в ОН Е$САРЕ. 
Команда ОН КЕѴ в этом случае игнорируется. Если действует 
только команда ОИ КЕУ и нажата любая, отличная от Е$с 
клавиша, то команда, указанная в ОИ КЕУ, выполняется после 
завершения текущей команды. Например, нажатие любой 
клавиши при выполнении индексирования файла с помощью 
команды ІНРЕХ в состоянии ОН КЕѴ не прерывает процесса 
индексирования. Если в буфере сохраняется значение клавиши, 
то команда, заданная в ОИ КЕУ, выполняется повторно. Следова¬ 
тельно, для правильного использования команды ОИ КЕУ нужно 
своевременно удалять из буфера сохраненное значение клавиши 
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с помощью функции ІИКЕѴО или команды КЕАР. Команда ОЫ 
ЕККОК обрабатывает только ошибки РВА5Е IV, включая синтакси¬ 
ческие ошибки, ошибки вычислений и ввода данных и др., но не 
ошибки на уровне операционной системы, например вследствие 
недоступности принтера или диска. 

В качестве команды, выполняемой после перехвата клавиши 
в состоянии ОЫ КЕѴ, нельзя использовать те же команды, что 
и при создании функции, определенной пользователем (см. 
команду РОНСКОЙ в разд. 3.6). 

Команда ОЫ КЕѴ ІАВЕІІ <имя клавиши > позволяет 
перехватить определенную нажатую клавишу. Имя этой клавиши 
можно задать неявно, поместив в переменную и использовав ее 
вместе с функцией макроподстановки &. Команда ОИ КЕѴ І.АВЕІ. 
без аргумента устанавливает перехват любой клавиши, как и 
команда ОН КЕѴ. Выполнение команды ОИ КЕѴ без опции после 
команды ОИ КЕѴ 1.АВЕІ. без аргумента отключает перехват 
клавишей. Состояние ОИ КЕѴ вызывает перехват клавишей во 
время выполнения команд ВКО>Ѵ$Е, ЕРІТ, КЕАР, меню и после 
выполнения всех команд. Такие команды, как Ы$Т, 50КТ и 
ІЫРЕХ, не прерываются до их завершения. Можно перехватывать 
любые клавиши, а также парные комбинации клавиш СІгІ, $ЬІМ, 
АІІ с функциональными клавишами, цифрами и буквами, а 
клавиши СІГІ также и с навигационными клавишами, например, 
СІгІ-РІ, АІІ-0, 5НІЙ-Р9, СІгІ-РдІір, СІгІ-РдРп и т.д. В качестве имен 
клавиш и их комбинаций выступает обычная запись, которая 
встречается везде по тексту. Исключение составляют навигацион¬ 
ные клавиши, имена которых должны быть представлены 
английскими словами: Вправо - РідЫаггоѵѵ, Влево - 1.еНаггож, 
Вверх - Цраггож, Вниз - Рпаггоѵѵ. Слова можно писать прописны¬ 
ми и строчными буквами или их комбинацией. Если клавиша 
запрограммирована командой 5ЕТ РІЖСТЮЫ и для нее установ¬ 
лен перехват командой ОЫ КЕѴ, то последняя имеет приоритет. 
Если команда ОИ КЕѴ перехватывает клавишу при вводе ее в 
переменную СЕТ, выполняется заданная в ОЫ КЕѴ команда и 
управление возвращается в точку перед этой командой. При 
этом перехваченный символ клавиши не помещается в перемен¬ 
ную СЕТ. Если в состоянии перехвата клавиши командой ОИ КЕѴ 
активна команда >ѴАІТ ТО < переменная >, последняя имеет 
приоритет и выполняется независимо от команды ОИ КЕѴ, 
причем перехватываемая клавиша заносится в переменную 
команды Ѵ/АІТ. 

Пример: 

ОН ЕМОК 00 Ргосегг 

РКОСЕРІЖЕ Ргосегг 
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СЖ ЕККОК 

кетуки 

ОИ КЕѴ ЭО 51ор 
РКОСЕОІІКЕ ЗТор 


УАІТ "Нажмите клавишу А для прекращения печати"*; 

" или любую клавишу для продолжения" ТО Оіѵеі 
ІР ІІРРЕК (01 ѵеѣ) = "А" 

ЯЕТОРИ ТО МА5ТЕК 
ЕИОІР 
ЯЕТОЯИ 

В примере, приведенном выше, для приостановки процесса 
последовательного выполнения программы используется команда 

>ѴАІТ [< сообщение >] [ТО < переменная >] 

которая вызывает паузу до нажатия любой клавиши и высвечи¬ 
вает в нижней строке экрана сообщение. После нажатия клавиши 
выполнение программы продолжается, а в переменную заносится 
код А5СІІ этой клавиши (для клавиши Епіег заносится нулевой 
код А5СІІ, а для непечатаемых клавиш - графический символ 
соответствующего кода). Сообщение представляет собой символь¬ 
ное выражение. Если сообщение не указано, то высвечивается 
стандартное сообщение: Рге$$ апу кеу Іог сопТіпие... (нажмите 
любую клавишу для продолжения). 

Пример: 

УАІТ "Будете продолжать? (У/И)" ТО Мсоп 
ІР ІІРРЕЯ (Мсоп) = ’Г 
КЕТІЖМ 
ЕЯОІР 

Часто при обработке ошибочной ситуации в процедуре 
(программе), вызываемой командой ОИ ЕККОК ЭО <имя 
программы >, использутся команда ЯЕТЯѴ, которая осуществляет 
повторное выполнение последовательности команд, вызвавших 
ошибку. Обычно в этой процедуре предусматриваются средства 
локализации и исправления ошибки. Следует однако учесть, что 
эта команда не выполняет повторно команд ІР или РО УЖІІ.Е. 

При использовании в программном файле команда КЕТКѴ 
закрывает этот файл и очищает значение, возвращаемое 
функцией ЕККОК(). Эта функция возвращает номер ошибки, 
указанной в перечне сообщений об ошибках. Текст сообщения об 
ошибке можно получить, используя функцию МЕ$$АСЕ(). 

Пример: 

* Главная программа Маіп 
ОИ ЕККОК 00 Сигі УІТН ЕКК0К() 

УЗЕ РИЕ1 
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КЕШИ 

* Программа Сигі 

РАКАМЕТЕК5 Ег 

ІР Ег = 3 

СЮ5Е ЭАТАВАЗЕЗ 

ЕИйІР 

ВЕТКУ 

КЕТМИ 

В приведенном примере в случае, если открывается уже 
открытый файл (ошибка с номером 3), вызывается процедура, 
в которой закрываются все файлы БД и затем осуществляется 
возврат на команду открытия файла, вызвавшую ошибочную 
ситуацию. 

Для отслеживания нажатых клавиш используются 
функции ІЫКЕѴЦп]) и І.А$ТКЕѴ() Числовой аргумент функции 
ШКЕѴ([п]) позволяет приостановить выполнение программы на 
заданное количество секунд. Если не нажата никакая клавиша, то 
возвращается ноль. Функция ІККЕѴ() вместе с возвращением 
кода клавиши удаляет ее значение из буфера клавиатуры. 

В табл. 3.5 представлены десятичные коды клавиш и их 
комбинаций. Функции ІЫКЕѴЦп]) и ЛАШЕУЦ используются в 
программах для перехвата нажатых клавиш с целью выполнения 
определенных действий. В принципе, с их помощью можно 
реализовать те же функции, что и командой ОИ КЕУ. 

Ниже приводится программа, в которой с помощью функции 
1_А$ТКЕѴ(} перехватывается клавиша, назначенная для вывода на 
экран информации. 

Пример: 

$ЕТ гименом 9 ТО СНК(16) && 16 - код АЗСІІ клавиши Сігі-Р 

00 ѴННЕ .Т. 

* Ввод данных в 6ЕТ переменные 

@ 19,40 $АУ "Для вывода данных нажмите Р9” 

КЕАО 

ІР 1.А5ТКЕУ () = -8 
00 ЗсгТопп 
Ю0Р 
ЕЬЗЕ 
ЕХІТ 
ЕИ0ІР 

Е N 000 

Здесь используется функция СН&(), которая возвращает 
символ, соответствующий его десятичному коду А5СІІ 
(более подробно см. разд. 3.7). При выполнении программы 
обработки ошибок с помощью команды ОН ЕККОК ЬО <имя 
программы > в начале этой программы целесообразно отключить 
буфер клавиатуры. Тем самым отключается состояние ОИ КЕѴ и 
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действие функции ІНКЕѴ(), что позволяет без помех обработать 
ошибочную ситуацию. 


Таблица 3.5. Десятичные А5СІІ коды клавиш 


Клавиша 

Код 

Клавиша 

< 

о 

С*г1-А 

1 

Р1 

28 

Сігі-В 

2 

С*г 1-Ноте 

29 

С*гТ-С 

3 

С1г1-Рд0п 

30 

С*г1-0 

4 

С*г 1-РдІІр 

31 

С*г1-Е 

5 

Пробел 

32 

Сігі-Р 

6 

ВаскІаЬ 

-400 

С*г1-6 

7 

С*г 1-Васкзрасе 

-401 

Сігі-Н 

8 

С*г 1-Еп*ег 

-402 

сиі-і 

9 

Р2 

-1 

Сігі-О 

10 

РЗ 

-2 

С*г1-К 

11 

Р4 

-3 

СТгЫ 

12 

Р5 

-4 

Сігі-М 

13 

Р6 

-5 

С*Ьг 1 -Ы 

14 

Р7 

-6 

С*г1-0 

15 

Р8 

-7 

С*г1-Р 

16 

Р9 

-8 

С*г1-0 

17 

Р10 

-9 

Сігі-К 

18 

С*г1-Р1 

-10 

С*г1-3 

ч 19 

СІГІ-Р2 

-11 

СІгЫ 

20 

СІгІ-РЗ 

-12 

с*гі-і) 

21 

С*г1-Р4 

-13 

Сігі-Ѵ 

22 

СІГІ-Р5 

-14 

Сігі-Ѵ 

23 

С*г1-Р6 

-15 

С*г1-Х 

24 

СІГІ-Р7 

-16 

С*г1-Ѵ 

25 

СРГІ-Р8 

-17 

СІгІ-2 

26 

СІГІ-Р9 

-18 

Езс 

27 

СІгІ-РІО 

-19 

5Н1РР-Р1 

-20 

А11-П 

-422 

5МРР-Р2 

-21 

АІР-о 

-421 

ЗЫРР-РЗ 

-22 

АН-р 

-420 

5НІРР-Р4 

-23 

АН-д 

-419 

ЗЫП-Р5 

-24 

АН-г 

-418 

5МРР-Р6 

-25 

АН-з 

-417 

5МРР-Р7 

-26 

АП-* 

-416 

5МРР-Р8 

-27 

А11 - и 

-415 

5Н1РР-Р9 

-28 

А1*-ѵ 

-414 

5ЫП-Р10 

-29 

АН-ѵу 

-413 

АН-а 

-435 

АН-х 

-412 

АП-Ь 

-434 

А11 -у 

-411 

АН-с 

-433 

АН-2 

-410 

АН-сІ 

-432 

АП-1 

-451 

АН-е 

-431 

АН-2 

-450 

АП-Р 

-430 

АН-3 

-449 

АН-д 

-429 

АН-4 

-448 

АП-Н 

-428 

АН-5 

-447 

АП-і 

-427 

АН-6 

-446 

АП-і 

-426 

АН-7 

-445 

АП-к 

-425 

АН-8 

-444 

АП-1 

-424 

АН-9 

-443 

АН-т 

-423 

АН-0 

-452 
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Отключить буфер можно, установив его размер равным 
нулю. Для этого используется команда 5ЕТ ТУРЕАНЕАР ТО 
<выр.И>, определяющая размер буфера клавиатуры (от 0 до 
32000 символов, по умолчанию 20), который также влияет на 
скорость ввода данных. Для увеличения скорости ввода данных 
нужно установить достаточно большой размер буфера, так как 
при определенной скорости ввода в буфере может накопится 
больше символов, чем его размер. При этом не помещающиеся 
в буфере символы теряются, что сигнализируется звуком, если 
$ЕТ ВЕН ои 

Команда $ЕТ ТУРЕАНЕАР ТО действует только в состоянии 
$ЕТ Е5САРЕ <Ж В командах ЕОIТ и АРРЕЫй буфер равен 20 
символам, независимо от установки команды $ЕТ ТУРЕАНЕАО. 
Описанная выше команда ОИ КЕУ позволяет перехватить 
нажатую клавишу или их комбинацию и выполнить ряд операций. 
Таким образом, клавише или их комбинации можно назначить 
выполнение определенных, специфических для конкретной 
прикладной программы действий. Для этой цели часто использу¬ 
ют функциональные клавиши и их комбинации. Назначение 
клавише определенных действий называется ее программирова¬ 
нием. Специально для программирования функциональных клавиш 
можно использовать команду 5ЕТ РІІЫСТІОН <выр.И>/ 
<выр. С>/<функциональная клавиша> ТО <выр.С>, которая 
позволяет поставить в соответствие функциональным клавишам 
Р2-Р10, комбинациям клавиш с 5ЫН-Р1 по 5НІТТ-Р9 и с СІгІ-РІ по 
СІТІ-Р1 0 строку длиной до 238 символов. Клавиша Р1 не програм¬ 
мируется и всегда используется только для вывода справочной 
информации. 

Функциональные клавиши можно задавать в виде их номера 
(см. ниже), символьного выражения или имени. Присвоенная 
клавише или их комбинации строка при их нажатии будет 
передаваться в соответствии с текущей операцией ввода. Если в 
конце строки поставить точку с запятой, то она будет интерпре¬ 
тироваться и выполняться как команда. В строку может входить 
несколько команд, в конце каждой из которых должна стоять 
точка с запятой. Клавиши 5ЫН-Р10, все комбинации функциональ¬ 
ных клавиш с клавишей АІі используются для вызова макроко¬ 
манд, поэтому их нельзя программировать. 

Команда 5ЕТ РІЖСТІОЫ позволяет задавать функциональную 
клавишу явно или в виде числового или символьного выражения. 
Выполняющая аналогичные функции команда ОИ КЕУ имеет 
приоритет перед командой $ЕТ РІІЫСТІОЫ. Если эти команды 
присваивают различные командные строки одной клавише, то 
выполняется строка, присвоенная командой ОИ КЕѴ. 

Функциональные клавиши Р1-Р10 имеют стандартные назначе¬ 
ния в виде команд, представленных в табл. 3.6. Назначения 
функциональных клавиш можно также установить с помощью 
меню команды $ЕТ, а также в файле Сопгід.сІЬ. 
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Таблица 3.6. Стандартные назначения функциональных клавиш 


Клавиша 

Команда 

Клавиша 

Команда 

Р1 

Неір; 

Р6 

гіізріау зіаіиз; 

Р2 

аззізЪ ; 

Р7 

сіізріау шетогу; 

РЗ 

Изі; 

Р8 

сіізріау; 

Р4 

сі і г; 

Р9 

аррепгі; 

Р5 

гіізріау зігисіиге; 

РІО 

егііі; 


Всего можно программировать 9 клавишей и 19 их комбина¬ 
ций. Запрограммированные клавиши и их комбинации нумеруются 
числами от 1 до 28, причем 1 присваивается клавише Р2 и т.д. 
в порядке их программирования. 

Примеры: 

ЗЕТ ПЖСТКМ РІО ТО '•ЗЕТ;” 

* При нажатии клавиши РІО выполняется команда ЗЕТ 

ЗЕТ РІЖТІОИ Р9 ТО "СІ-ЕАК ;ЫЗЕ Ріо;И$Т;" 

* Выполняет последовательность команд СІ.ЕАК, ІІЗЕ , И5Т 

Функция РКІ.АВЕІ. (<выр.И>) позволяет определить 

клавишу или их комбинацию, которая имеет заданный номер. 
Эту функцию можно использовать в прикладных программах при 
переназначении функциональных клавиш в зависимости от 
решаемой задачи. Кроме стандартной клавитуры ІВМ существуют 
другие, в которых может быть иное число программируемых 
клавиш. Для возвращения общего числа таких клавиш использует¬ 
ся функция РКМАХ(). 

В программах при выполнении операций с полноэкранными 
командами типа ВКО\Ѵ5Е, ЕЭІТ, АРРЕИй, СМАЫСЕ, СКЕАТЕ, 
МОЭІРѴ, @...$АѴ...ОЕТ и КЕАЭ нередко требуется определить, 
были ли внесены изменения в файл БД. Для этого используется 
команда КЕАОКЕѴО, которая возвращает код (целое число), 
определяющий клавишу, нажатую перед выходом из полноэкран¬ 
ной команды. Это число зависит от того, обновлялись или 
остались неизменными данные при выполнении команды. В табл. 
3.7 приведены коды клавиш выхода из полноэкранных команд. 

Пример: 

ІГ КЕА0КЕѴ( )>=256 && Данные обновлены 

КЁР1.АСЕ Ок 1 ас! ѴІТН Зиш 

ЕМІР 

В гл. 2 были описаны действия по созданию экранных форм 
ввода и вывода данных с помощью меню УЦ. Данная функция 
реализуется с помощью специальной полноэкранной команды 
СКЕ АТЕ/МОй I РУ 5СКЕЕИ <имя файла >/?, которая передает 
управление в окно Рогтз УЦ для разработки (изменения) 
экранных форм ввода-вывода информации и позволяет создать 
(изменить) файл экранной формы. 
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Таблица 3.7. Возвращаемые коды клавиш 


Без 

обнов¬ 

ления 

После 

обнов¬ 

ления 

г 

Клавиша 

Назначение 

0 

256 

СІг1-5,Сіг1-Н, 

Назад на один символ 

- 

256 

Васкзрасе 

Назад 'на один символ 

1 

257 

Сіг 1-Э, Сіг 1-І_ , 

Вперед на один символ 

4 

260 

Сігі-Е .С'кгі-К, 

Назад на одно поле 

5 

261 

С"Ьг1-0 .С'ЬгІ-Х, 

Вперед на одно поле 

6 

262 

Сігі-К, РдІІр 

Назад на один экран 

7 

263 

С1: г 1 -С г РдОп 

Вперед на один экран 

12 

- 

Сіг1-(), Езс 

Завершить без сохранения 

- 

270 

Сіг1-Ѵ ,С1г 1-Епс1 

Завершить с сохранением 

15 

271 

Епіег,Сіг1-М 

Ввод или заполнение 
последней записи 

16 

— 

Епіег,Сіг1-М ! 

В начало записи при 
добавлении 

33 

289 

Сігі-Ноте 

Переключение меню 

34 

290 

г 1 -РдІІр 

Выход из полного экрана 

35 

291 

Сіг 1-РдЭп 

Вход в полный экран 

36 

292 

Р1 

Клавиша помощи 


При разработке экранной формы сначала создается файл 
разработки экранной формы с расширением .$сг. На основе этого 
файла генерируется программный файл с расширением .(ті, 
содержащий команды СЕТ и ВЕЛО, обеспечивающие 

ввод и вывод данных и другие действия при работе с экранной 
формой. 

Файл разработки с расширением .$сг предназначен не только 
для генерации файла .(ті, но и для последующей модификации 
экранной формы. Если файл .$сг уничтожен, то тогда уже нельзя 
модифицировать файл экранной формы с помощью команды 
СВЕАТЕ/МООІРѴ 5СВЕЕИ. Однако всегда остается возможность 
непосредствен© модифицировать программный файл экранной 
формы с расширением .(ті с помощью текстового редактора 
СІВА5Е IV, вызываемого командой МОРІРѴ СОММАНО. Можно 
также использовать любой другой текстовой редактор. После 
первого открытия файла экранной формы типа .(ті на его 
основе псевдокомпилятором СІВА5Е IV создается файл с 
расширением .(то (объектный модуль), который предназначен 
для непосредственного выполнения. В программах файл экранной 
формы можно открыть командой $ЕТ РОКМАТ ТО <имя файла 
экранной формы >) и закрыть командой $ЕТ РО&МАТ ТО как 
обычный файл, что позволяет выполнить обработку файла БД в 
соответствующей экранной форме. Опция ? команды СКЕАТЕ/ 
МОРІРѴ 5СКЕЕИ, альтернативная заданию имени файла экранной 
формы, позволяет, если открыт каталог, высветить на экране 
список файлов типа .$сг, связанных с активным файлом БД или 
выборкой. Если каталог закрыт, то эта опция высвечивает список 
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файлов .$сг на текущем диске. После появления списка файлов 
,$сг на экране можно выбрать один из них для модификации. 

В СІВА5Е IV можно также использовать файлы экранных 
форм, созданные в сІВАЗЕ III + . После открытия такой файл 
преобразуется в формат сІВАЗЕ IV и ему присваивается расшире¬ 
ние .5сЗ. Файлы экранных форм, разработанные в сІВАЗЕ IV, 
нельзя использовать в сІВАЗЕ 111 + (более подробно о разработ¬ 
ке экранных форм ввода и вывода данных с помощью режима 
УЦ, управляемого меню, см. в разд. 2.5). 

В программах обработки файлов, когда используются 
несколько экранных форм ввода и вывода информации, нередко 
после вызова формы требуется очистить или закрасить опреде¬ 
ленную область экрана. Очистку можно сделать командой 

@ <строка 1 >,<колонка1 > СІ-ЕАК 
[ТО <строка2>, <колонка2>] 

которая удаляет содержимое прямоугольной области экрана, 
определяемую координатами верхнего левого - <строка1>, 
<колонка1> и правого нижнего - <строка2>,<колонка2> - 
углов прямоугольника. Если не указаны координаты правого 
нижнего угла, то очищается строка, начиная с позиции 
<колонка1 >. 

Пример: 

0 2,10 СІ.ЕАК ТО 15,79 

Для закрашивания части экрана используется команда 

@ <строка 1 >,<колонка1 > НИТО <строка2>,<колонка2> 
[СОЮК <код цвета >] 

Эта команда закрашивает прямоугольную область экрана, 
определяемую координатами верхнего левого - <строка1>, 
<колонка1> и правого нижнего - <строка2> , <колонка2> - 
углов прямоугольника. Коды цвета приведены при описании 
команды $ЕТ СОЮК. 

Пример: 

0 2,10 ГІИ ТО 15,79 СОЮК К/В 

С целью улучшения восприятия информации на экране 
можно использовать команду 

@ <строка 1 >,<колонка1 > ТО <строка2>,<колонка2> 
[ООІІВІ.Е/РАНЕІ./< символы определения рамки>] 
[СОЮК <код цвета >] 

которая рисует на экране прямоугольную рамку, определяемую 
координатами верхнего левого - < строкаі >, < колонкаі > - и 

правого нижнего - < строка2 >, < колонка2 > - углов рамки. 

Опция ООІІВІ.Е позволяет рисовать двойную линию рамки (по 
умолчанию рисуется одинарная линия), опция РАИЕІ. - рамку в 
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виде сплошной полосы. Кроме того, имеется возможность 
рисовать линию рамки заданными символами. Для этого задается 
список символов для определения рамки. Можно задать 
различные символы для сторон и углов рамки. В этом случае 
символы разделяются запятыми и располагаются в следующем 
порядке: 1, Ь, I, г # ІІ, 1т, Ы, Ьг, где ♦ - верх; Ь - низ; I - левая 
сторона; г - правая сторона; 11 - левый верхний угол; 1т - правый 
верхний угол; Ы - левый нижний угол; Ьг - правый нижний угол. 

Пример: 

Ѳ 5.13 ТО 10.40 йОтЕ СОЮК К/В6 

Для полной очистки всего экрана используется команда 

О.ЕАК [АИ/РІЕЬ05/ОЕТ$/МЕМОКѴ/МЕМІІ$/ 
РОРиР$/ТУРЕАНЕАО/\У1ЫООУ/$] 

Она очищает экран, устанавливает курсор в левый нижний угол 
экрана и освобождает все незаконченные опции СЕТ команды 
@...5АѴ...СЕТ. Различные опции этой команды также закрывают 
файлы БД, очищают переменные, списки полей, окна, горизон¬ 
тальные и вертикальные меню и буфер клавиатуры. 

Опция АЬЬ закрывает все открытые файлы БД, горизонталь¬ 
ные и вертикальные меню, очищает все переменные (за 
исключением системных переменных), элементы массивов и 
выбирает рабочую область 1. Одновременно закрываются все 
связанные индексные файлы (.псіх и .тсіх), файлы экранных 
форм (.Іті) и файлы Мето (.сІЫ), а также файл каталога 
(.саі). 

Опция РІЕІ.05 освобождает список полей, созданный 
командой 5ЕТ РІЕІ.05. В отличие от команды 5ЕТ РІЕІ_0$ ТО, 
которая удаляет активные поля файла БД из списка полей, 
данная команда освобождает все поля, в том числе включенные 
из других рабочих областей. Выполнение этой опции автоматичес¬ 
ки влечет выполнение команды $ЕТ РІЕЮ5 ОРР. Опция СЕТ5 
освобождает все команды (3)...ОЕТ, следующие после последней 
выполненной команды СІ.ЕАК АН, СІ.ЕАК СЕТ5 или КЕАР. По 
умолчанию разрешается использовать до 128 опций СЕТ перед 
командами СІ.ЕАК СЕТ5 и КЕАй. Опция МЕМОРУ освобождает 
все переменные (за исключением системных) и элементы 
массивов. Опция МЕИІІ5 очищает все горизонтальные меню, 
опция РОРІІР5 все вертикальные меню, а опция >УІИОО>У$ все 
окна с экрана и удаляет их из памяти. Опция ТУРЕАНЕАО - 
освобождает буфер клавиатуры. 

Команда @...5АУ...СЕТ является универсальной для организа¬ 
ции ввода и вывода информации на экране. В программах 
нередко требуется вводить с клавиатуры данные для обеспечения 
процесса обработки информации, например имя файла БД, 
данные для ветвления программы, поисковые значения и т.д. Для 
этого предусмотрена специальная команда 
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АССЕРТ [<сообщение>] ТО <перѳменная> 

которая позволяет вводить с клавиатуры данные символьного 
типа в переменную. Перед полем переменной можно высветить 
сообщение, например о характере вводимых данных. Это 
сообщение представляет собой символьную строку (должна 
заключаться в двойные, одинарные кавычки или квадратные 
скобки), переменную или любое символьное выражение длиной 
до 254 позиций. После набора данных с клавиатуры для ввода 
их в переменную следует нажать клавишу Епіег. 

Пример: 

АССЕРТ "Введите имя:" ТО паше 

Кроме этой команды для ввода данных с клавиатуры можно 
использовать команду 

ІЫРІРТ [<сообщение>] ТО <переменная> 

которая выполняет аналогичные функции, но позволяет вводить 
в переменную с клавиатуры данные не только символьного, но 
и других типов, а также в виде заданного выражения, что не 
допускается в команде АССЕРТ. Тип выражения определяет тип 
переменной, в которую вводится значение. После набора 
выражения с клавиатуры для ввода его в переменную надо 
нажать клавишу Епіег. 

Следует напомнить, что вводимые данные типа даты должны 
заключаться в фигурные скобки. Если же дата вводится без этих 
скобок (т.е. в виде символьной строки), то для преобразования 
в данные типа даты следует использовать функцию стойп 
(более подробно см. разд. 3.7). 

При разработке экранных форм весьма полезными являются 
функции СОЦ) и КО^(), которые возвращают текущий номер 
колонки и строки расположения курсора. Эти функции можно 
использовать для относительной адресации позиций экрана в 
команде @...$АѴ...СЕТ, например @ 5,СОЦ)... Вместо функции 
СОШ для этой цели можно использовать специальный оператор 
$’• @ 5,$, но функция СОЦ) работает быстрее. С помощью 
относительной адресации можно, например, выводить информа¬ 
цию в различные места на экране с помощью одной процедуры. 
Фрагмент такой процедуры может включать: 

К0Ѵ() = пгоѵ* 

СОЦ) = псо 1 

РО УНIиЕ СОК) < есо 1 

Ѳ К0М(),СОК) + 5 $АѴ "I м 

Е N 000 

Как уже указывалось выше, программирование клавиш можно 
выполнить не только командой 5ЕТ РІЖСТЮЫ, но и командой 
$ЕТ. Это полноэкранная управляемая с помощью меню команда 
предназначена для высвечивания и изменения значений многих 
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команд $ЕТ. При выполнении этой команды высвечивается меню, 
состоящее из пяти позиций: 

Орііопз - высвечивает значения, установленные по умолчанию 
для многих команд $ЕТ. Эти значения можно изменить с 
клавиатуры; 

Оізріау - позволят изменить цвет и интенсивность высвечива¬ 
емого текста, заголовков, строки состояния и полей. Сохранение 
изменений выполняется клавишами С1г1-Еп<1. Изменения сохраня¬ 
ются в течение текущего сеанса. При выходе из СІВА5Е IV все 
цвета (кроме интенсивности свечения) возвращаются в исход¬ 
ные; 

Кеу$ - позволяет программировать клавиши и их комбина¬ 
ции; 

О'нк - позволяет изменять заданный по умолчанию диск и 
маршрут по директориям; 

РіІе$ - позволяет задавать: альтернативные файлы, файлы 
экранных форм, тип выходного устройства и файлы индексов. 

В программах нередко требуется определить текущее 
состояние команд $ЕТ. Для этого можно использовать функцию 
5ЕТ(<выр.С> ), которая возвращает целое число или значение 
ОН или ОРР команд $ЕТ. 

Символьное выражение <выр.С> представляет собой 
ключевое слово команды. Если в команде $ЕТ устанавливается 
целое числовое значение и значения ОИ и ОРР, то возвращается 
только сж или ОРР 

Примеры: 

? ЗЕТСВЕИ") && Высвечивает ОМ 

? 5ЕТ ("САЙКУ") && Высвечивает ОРР 

3.5. СОЗДАНИЕ ОТЧЕТОВ И МАРОК 

Команда @...5АѴ...СЕТ, описанная в предыдущем разделе, 
предназначена для ввода информации с клавиатуры в поля файла 
БД, массивы и переменные и вывода ее на экран. 

Опция 5АѴ позволяет также выводить эту информацию и на 
принтер. Кроме этой универсальной команды существует 
команда, специально предназначенная для вывода данных на 
экран и принтер: 

?/?? [<выр. 1 > [РІСШКЕ <выр.С>] 

[РІІНСТІОН <список функций>] [АТ <выр.Ы>] 

[5ТѴІ.Е <номер шрифта>]] [,<выр.2>...] [,] 

которая выводит значение одного или более заданных символь¬ 
ных выражений. Если установлено состояние 5ЕТ РРІНТ ОИ, то 
выполняется вывод на принтер, если $ЕТ РРІИТ ОРР, то на экран. 
Эта команда в форме ? выводит каждое выражение на следую- 
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щей строке, а в форме ?? все выражения на одной строке. 
Опции РІСТІІКЕ и РІЖСТЮИ, так же, как и в команде @...$АѴ... 
СЕТ, позволяют форматировать вывод. 

Для форматирования используются шаблоны и функции поля. 
В качестве знаков шаблонов используются те же, что описаны в 
команде СЕТ. 

Из числа функций поля последней команды в данной 
используются только шесть, а две функции введены новые. Всего 
в данной команде предусмотрено восемь функций поля, которые 
обозначаются буквами Н, V, В, I, I , Т, $, І_. Последние шесть 
описаны в команде @...$АѴ...СЕТ. 

Функция @Н<п> позволяет делать горизонтальную, а 
@Ѵ<п> - вертикальную развертку поля данных, где п - 

максимальное количество колонок или строк выводимого поля. 
Эти функции по-разному обрабатывают длинные и короткие поля. 
Длинными считаются поля, длина которых превышает шаблон 
опции РІ СТУКЕ команды ?/??, а короткими - поля, которые не 
заполняют целиком этот шаблон. 

Функция @Н развертывает длинные поля горизонтально 
вправо и вниз, раздвигая вправо и влево короткие поля и другой 
текст по соседству, если не присутствует опция АТ, в которой 
задается позиция левой колонки начала вывода. 

Для горизонтальной развертки должно быть установлено 
значение .Т. системной переменной _ѵѵгар (более подробно о 
системных переменных см. ниже в этом разделе). 

Ширина колонки при выводе поля Мето устанавливается 
командой 5ЕТ МЕМО\ѴЮТН ТО <выр.Н> ( по умолчанию 50 
позиций). Ее можно также установить в файле СопІід.сІЬ. 
Максимальное значение ширины колонки 32000, минимальное 8. 

При выводе на печать поля Мето в случае использования 
функции шаблона @Н его содержимое развертывается внутри 
границ, определенных системными переменными _1тагдіп и 
_гтагдіп, а установленная командой $ЕТ МЕМО>ѴЮТН ширина 
поля игнорируется. 

Функция @Ѵ<п> развертывает длинные поля вертикально 
вниз в колонке заданной ширины. Эта функция может использо¬ 
ваться для развертки по вертикали и поля Мето. Если п = 0, то 
поле Мето развертывается в пределах ширины, установленной 
командой $ЕТ МЕМОѴѴЮТН. 

При совместном использовании функции @Ѵ и шаблона 
РІСШКЕ для вывода поля Мето его текст может быть обрезан 
в конце, если длина строки больше, чем установлено в шаблоне. 

Функции @В, @1 или (8М перекрывают установку системной 
переменной _аІідптепі и позиционирование текста в поле Мето. 
Если в конце команды ?/•• стоит запятая, то при вертикальной 
развертке сначала печатается только первая строка до тех пор, 
пока не встретятся команды КЕТШЖ, ЕИОРКІЫТІОВ или команда 
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?/?• без запятой в конце. Это позволяет выводить ряд полей в 
одной строке с помощью нескольких команд ?? и управлять 
выводом второй и последующих строк полей при их вертикаль¬ 
ной развертке. 

Опция 5ТѴІ.Е предназначена для вывода на печать текста 
различными шрифтами, например жирным или наклонным. Номер 
шрифта обозначается условными буквами, цифрами или их 
комбинацией. В качестве условных букв используются: В - 
жирный, I - наклонный, II - с подчеркиванием, В - приподнятый, 
I. - опущенный. Можно вместо букв задавать цифры от 1 до 5, 
которые соответствуют шрифтам, предварительно определенным 
в файле Сопіід.сІЬ с помощью параметра РКІИТЕК (см. о файле 
СопЛд.сІЬ в разд. 3.1). 

Опция 5ТѴ1.Е позволяет, комбинируя шрифты, печатать текст 
на одной строке в различном стиле. Для изменения типа шрифта 
можно также использовать команду ??? и системные переменные 

_р5сосІе и _ресос!е. 

Команда ? без опций выводит одну пустую строку. Для 
пропуска одной или нескольких строк можно также использовать 
системную переменную _р$расіпд. 

Пример: 

аі ідптеп*="І_ЕРТ" 

_ѵугар= . Т. 

? Мте РІСТІЖЕ ”!ХХХХХХХХХХХХХХ" РІЖТШ ІѴ15 

В этом примере поле Мето с именем Ыате разворачивава- 
ется вертикально в пределах 15 позиций, определенных шабло¬ 
ном РІСТІІКЕ. Функция вертикальной центрированной развертки 
перекрывает ранее определенную установку значения переменной 
__ аіідтепі = 'ТЕРТ". Если в этом примере задать горизонтальную 
развертку, то текст будет центрирован между значениями 
_Ітагдіп и _гтагдіп. 

Если значение переменной __ ^гар = .Р., то при выводе на 
печать поля Мето с использованием функции @Н печать 
начинается с текущей позиции (или определенной значением 
__ рсоіпо) и эта позиция становится левой границей. < При этом 
сохраняются установленные в поле Мето границы, абзацы и 
страницы. 

Пример: 

УЗЕ РІО 

ЗЕТ РІШТ ОМ 

? ММ "В", 0ЮЕ1_ 5ТѴІ.Е "В". РАМ 5ТПЕ "I" 

Из базы данных РІО на печать выводится жирным шрифтом 
поля ИІІМ и ОЮЕІ_, а наклонным шрифтом поле РАМ. 

Вместо опций РІСШКЕ и РІЖСТІОМ в команде 4 можно 
использовать функцию ТКАЫ$РОКМ( < выр. >, < выр.С> ), которая 
преобразует заданное выражение в соответствии с указанным в 
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аргументе <выр. С> шаблоном. Эту функцию можно также 
включать и в другие команды, например РІ5РІ.АѴ, І.АВЕІ., И5Т 
и КЕРОКТ. 

Пример: 

УЗЕ Касігу 

* Выводит в разрядку Иванов 

? ТКАН$РОКМ(Рат, "ѲК ХХХХХХХХ X й ) 

Для точного размещения поля Мето перед выводом его на 
экран или на печать с помощью команд ?/?? или (а)...$АѴ...СЕТ 
в форме вертикальной развертки нередко целесообразно 
определить, сколько строк оно занимает. Для этого используется 
функция МЕМЫНЕ$( < имя тепло поля>), которая возвращает 
число строк в поле Мето при его вертикальной развертке. Для 
извлечения из поля Мето заданной строки используется функция 
МЫИЕ(<имя тепло поля>, <выр.Ы>). 

Выводом на печать обычно управляет драйвер - специальная 
программа, которая интерпретирует посылаемые на принтер 
символы. В ряде случаев требуется обращаться к принтеру 
напрямую, минуя драйвер, например, если драйвер не поддер¬ 
живает определенные символы. Для этого применяется команда 
Ш <выр.С>, которая выводит содержимое заданного выражения 
непосредственно на принтер, минуя драйвер. Эта команда 
позволяет передать на принтер символы, не изменяя текущей 
позиции строки и колонки. 

Различные типы принтеров имеют свои собственные управля¬ 
ющие коды, которые приводятся в руководствах по использова¬ 
нию. Управляющие коды могут включать любые печатаемые 
символы за исключением знака двойных кавычек ("), а также 
непечатаемые символы, как, например, Е$с. Непечатаемые 
символы могут быть определены различными способами, в том 
числе с помощью спецификаторов. Спецификаторы управляющих 
символов представляют собой строки, которые идентифицируют 
непечатаемые символы. Они должные быть заключены в 
фигурные скобки {}. 

В табл. 3.8 приводятся спецификаторы управляющих симво¬ 
лов. 

Предположим, нужно послать управляющий код Е$с-Е (этот 
код перезагружает принтер) на лазерный принтер НеѵѵІеН-РаскагсІ. 
Зная, что код А5СІІ для Е$с - 27, а для Е - 69, можно сформи¬ 
ровать команду различными способами: 

с использованием функции СНК(), которая преобразует 
числовой код в эквивалентный символ А С 511: ??? СНР(27) + М Е" 

с использованием спецификатора управляющего кода: ??? 
"{Е$С}Е' # 

с использованием только кодов А5СІІ, заключая их в 
круглые скобки: ??? "{27}{69}" 

с использованием комбинации кодов А5СІІ и букв: ??? ”{27}Е" 
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Таблица 3.8. Спецификаторы управляющих кодов 


Код АЗСII 

Спецификатор управляющего кода | 

0 


МП } или { СТР1.-0 } 1 

1 


стрі_-а 


2 


ст-в 1 


3 


ст-с 


4 


ст-о 


5 


СТРІ.-Е 


6 


ст-г 


7 


ВЕН. } или { ст-6 } 

8 


ВАСК5РАСЕ } или { СТКІ.-Н } 

9 


ТАВ } или { СТКІ-І } 

10 


1ЛИЕРЕЕ0 } или { СТКІ.^ } 

11 


ст-к 


12 


ст-і. 

■ 

13 


КЕТІЖИ 

или { СТК1.-М } 

14 


ст-и 


15 


ст-о 

■ 

16 


СТР1_-Р 

■ 

17 


ст-о 

' 

18 


ст-р 

■ 

19 


’ ст-з 

' 

20 


1 ст-т 

■ 

21 

і 

ст-іі 

• 

22 

\ 

ст-ѵ 

• 

23 

і 

’ ст-ѵ 

• 

24 

< 

СТРІ.-Х 

■ 

25 

< 

СТРІ.-Ѵ 

■ 

26 

« 

' СТР1.-2 

' 

27 


. Е5С } и л и { Е5САРЕ }или{ Ст-[> 

28 


ст-\ 

► 

29 


стт-] 

> 

30 


СТР1_- Л 

> 

31 


СТРІ.- 

> 

127 


( 0Е1_ } или { 0Е1.ЕТЕ } | 


Системные переменные представляют собой переменные, 
которые создаются и поддерживаются автоматически в сІВАЗЕ IV. 
Эти переменные обеспечивают форматирование вывода информа¬ 
ции на экран и принтер, а также установку параметров принтера. 
В частности, системные переменные позволяют установить: 

характеристики печати, такие как способ подачи бумаги и 
количество печатаемых копий; 

оформление параграфов, например, выравнивание текста, 
абзац и границы; 

общие характеристики печатаемой страницы - шаг и качество 
печати, длину страницы и сдвиг печати слева. 

Имена системных переменных начинаются с символа 
подчеркивания для отличия от обычных переменных. После 
запуска сІВАЗЕ IV автоматически устанавливаются значения 
системных переменных, принятые по умолчанию. Эти значения 
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можно изменять при разработке экранных форм, отчетов и 
марок в УЦ, в командном режиме или в программах. После 
завершения работы программы с системными переменными, 
содержащими частные значения, они устанавливаются в первона¬ 
чальные значения. Команды С1.ЕА& МЕМОКѴ и КЕІ.ЕА5Е (см. 
разд. 3.6) не удаляют системные переменные из памяти. Многие 
системные переменные управляют потоком выходных данных. 
Этот поток формируется рядом команд, выводящих данные, за 
исключением команд @...$АѴ...ОЕТ, @...ТО и Е.ІЕСТ. Выходной 
поток обычно направляется на определенное устройство. 
Устройство, на которое выводится поток выходных данных, 
можно установить командами $ЕТ С0И501.Е, $ЕТ РКІЫТЕК и $ЕТ 
АНЕКИАТЕ, а также опцией ТО РКШТЕК/ТО РНЕ команды 
Ы$Т/ОІ$РІ.АѴ. Выходной поток выводится на экран с текущей 
позиции курсора, на принтер - с текущей позиции головки 
принтера и в файл на диске - с текущей позиции указателя 
записей. Команды @...$АѴ...СЕТ и @...ТО не создают выходной 
поток данных, но они могут влиять на последующий вывод 
выходного потока посредством установки текущей позиции 
курсора или головки принтера. 

Кроме определения устройства для вывода выходного потока, 
для контроля вывода и других целей, например, сохранения 
копии выходного потока, предусматривается автоматическое 
создание альтернативного файла выходного потока, записывае¬ 
мого на диск. Этот текстовый файл, называемый также АІ.ТЕК- 
ИАТЕ, записывается параллельно основному выводу командами 

5ЕТ АНЕКЫАТЕ ТО [<имя файла> [ЛОЭІТІѴЕ]] 

5ЕТ АИЕКНАТЕ ОИ/ОРР 

Первая форма команды создает и открывает текстовой файл 
с заданным именем, а вторая (5ЕТ АНЕКМАТЕ ОН) записывает 
в него всю выводимую информацию. Напомним, что полноэкран¬ 
ные команды @...$АѴ...СЕТ, ВКОѴѴ5Е, ЕОІТ, АРРЕИЭ и др. не 
формируют выходной поток данных, следовательно, альтернатив¬ 
ный файл в этом случае не создается. 

При записи выходного потока командой ? в начало альтерна¬ 
тивного файла записывается пустая строка, так как данная 
команда всегда предварительно выполняет возврат каретки, что 
равносильно записи пустой строки. Чтобы избежать этого, следует 
использовать команду ??. Если файл с заданным именем уже 
существует, он замещается новым. Команда 5ЕТ АНЕКИАТЕ ТО 
без имени файла или команда СІ.05Е АНЕКЫАТЕ закрывают 
альтернативный файл. 

Опция АРРІТІѴЕ устанавливает курсор в конец альтернатив¬ 
ного файла перед записью в него информации, что позволяет 
добавлять данные. Команда $ЕТ АІ.ТЕ&ЫАТЕ ОРР позволяет 
прервать запись в альтернативный текстовый файл без его 
закрытия. Затем можно возобновить запись командой 5ЕТ 
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АНЕКИАТЕ ОМ. Альтернативный текстовый файл не закрывается 
до тех пор, пока не будет выполнена команда СІ.ОЗЕ АІ.ТЕКЫАТЕ 
или ЗЕТ АІЛЕКИАТЕ ТО. Перед открытием этого файла целесооб¬ 
разно проверить, был ли он закрыт или, на всякий случай, 
выполнить команду СЮЗЕ АНЕКЫАТЕ. Это, впрочем, не лишняя 
предосторожность и при открытии любого файла. Созданный 
командой ЗЕТ АНЕКЫАТЕ файл является стандартным текстовым 
файлом А5СІІ и его можно редактировать текстовым редактором 
сІВАЗЕ IV, который вызывается командой МОйІРѴ СОММАЫО, 
или в УЦ выбором позиции сіВАЗЕ ргодгат после выбора 
позиции <сгеаіе> окна генератора прикладных программ. 
Можно также использовать любой другой текстовый редактор. 

Примеры: 

ЗЕТ АНЕЛШЕ ТО ТЕХТРИЕ && Создает текстовый файл 

ЗЕТ АНЕКИАТЕ ОИ && Инициирует запись информации 

ЗЕТ АНЕКИАТЕ ОРР && Приостанавливает запись 

ЗЕТ АНЕМАТЕ ОИ && Возобновляет запись 


СЮЗЕ АНЕКИАТЕ && Закрывает текстовый файл 

Для вывода на экран данных, набираемых с клавиатуры, а 
также выходного потока данных используется команда ЗЕТ 
СОИЗОІ.Е ОИ (устанавливается по умолчанию). Команда ЗЕТ 
СОИЗОІ.Е ОРР подавляет вывод на экран выходного потока и 
набираемых с клавиатуры данных. В частности, не высвечиваются 
данные, набираемые с клавиатуры в командах >ѴАІТ или АССЕРТ, 
что исключает визуальный контроль введенной информации. При 
этом не выводятся также сообщения этих команд. Однако не 
подавляется информация, выводимая командой @...ЗАѴ...СЕТ, а 
также сообщения об ошибках и предупреждения при удалении 
и перезаписи файлов. Эту команду можно использовать только 
в программах, а не в командном режиме. 

Для вывода информации на принтер командами, формирую¬ 
щими выходной поток (например, ?/??, ЗЕТ ТАІ.К, ЫЗТ и других, 
кроме @...ЗАѴ), необходимо установить состояние ЗЕТ РКШТЕК 
ОИ (ОРР - задается по умолчанию). Вывод на принтер инфор¬ 
мации командами @...5АѴ осуществляется командой ЗЕТ РЕѴІСЕ 
ТО РКШТЕК. 

Команда ЗЕТ РКІЫТЕК ТО без аргумента восстанавливает 
заданное по умолчанию устройство вывода (локальное печатаю¬ 
щее устройство, общий принтер ЛВС или файл на диске). При 
работе в среде ЛВС эта команда также выдает сигнал серверу 
файлов печатать следующее задание. Эта команда имеет еще 
пять форм: 

ЗЕТ РКШТЕК ТО < устройство РОЗ> 

ЗЕТ РКШТЕК ТО \\ <имя компьютера> 
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\<имя принтера> = <назначение> 

5ЕТ РКЫТЕК ТО \\ 5РООІ.ЕК 
5ЕТ РКІНТЕК ТО \\ САРТЦРЕ 
5ЕТ РИШТЕ* ТО РНЕ <имя файла> 

Первые четыре формы используются для назначения и 
переназначения вывода информации на различные устройства 
печати, а пятая создает файлы, форматированные для печати. 
Первая форма команды выводит информацию на локальный 
принтер (по умолчанию устройство печати 005 РРІЧ) в один из 
трех параллельных (1.РТ1, 1.РТ2, ЬРТЗ) или последовательных 

портов (СОМ1 или СОМ2). Эту команду можно также использо¬ 
вать для восстановления установленного по умолчанию устройства 
печати 005 с одновременным запуском на печать следующего 
задания в файловом сервере. 

Пример: 

5ЕТ РКШЕК ТО 1.РТ1 

Формы команды 5ЕТ РИШТЕ* ТО <аргументы> со второй 
по четвертую используются при работе в среде ЛВС. При работе 
в ЛВС ІВМ РС и ЗСот первый аргумент второй формы задает 
имя файлового сервера, второй - имя принтера в ЛВС и порт 
1_РТ1...[_РТЗ. 

Пример: 

5ЕТ РКШЕК ТО \\$ЕКѴЕК\ЕР$0М=1_РТ1 

Пятая форма команды 5ЕТ РНШТЕН ТО РIЕЕ применяется для 
создания форматированного для печати файла и записи его в 
файл 005. Если этот файл создается с помощью драйвера 
печати А5сіі.рг2, то формируется текстовой файл А5СІІ, который 
можно выводить на любой принтер с построчной печатью или 
передавать по каналам связи. В СІВА5Е IV по умолчанию 
создается текстовой файл с расширением .ргі Чтобы получить 
текстовый файл А5СІІ с расширением Лхі, нужно использовать 
драйвер печати А$сіі.рг2. Для этого можно присвоить системной 
переменной _рсІгіѵег значение " А$сіі.рг2". Аналогично выполня¬ 
ются другие назначения драйвера. В частности, для получения 
файла, форматированного под лазерный принтер НеѵѵІеіі-РаскагсІ 
І.а$ег.Іеі, следует присвоить: _ рсігіѵег = "НрІа$1 00.рг2". 

После этого выполняется команда 5ЕТ РНШТЕН ТО РНЕ 
<имя файла>. Созданный файл впоследствии можно распечатать 
на лазерном принтере. 

Примеры: 

СОРУ А:<имя файла>.РКТ СОМ1 

* Распечатывается файл с диска А: на лазерном принтере 

* подсоединенном к последовательному порту С0М1 

ЗЕТ РКШЕК ТО \\А$ЕКѴЕК\РІШТЕК=ІРТ1 
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* Назначает вывод информации на устройство печати с именем 

* РКІИТЕГС и портом 1.РТ1, подключенным к компьютеру с именем 

* А5ЕКѴЕК в ЛВС 

КЕРОКТ РОКИ Ріо ТО РКШЕК 

ЗЕТ РЯIЫТЕЯ ТО І.РТ1 && Выводит информацию из буфера на принтер 

Изложенный в гл. 2 процесс разработки отчетов и марок в 
режиме УЦ, управляемом меню, можно реализовать с помощью 
полноэкранных команд. Команда СЯЕАТЕ/МООІРУ ЯЕРОЯТ <имя 
файла отчета>/? передает управление на экран разработки 
(изменения) отчета в УЦ и позволяет создать или изменить 
файл разработки отчета с расширением Лгт. Команды СЯЕАТЕ и 
МОйІРУ идентичны. Если указано имя существующего файла, то 
его можно модифицировать. В противном случае оно рассматри¬ 
вается как имя нового файла. 

Опция ? высвечивает все существующие файлы отчетов, 
связанные с активным файлом БД, которые можно модифициро¬ 
вать после их выбора. Файл разработки отчета с расширением 
.Ігт служит для генерации исходной программы выполнения 
операций по формированию и печати отчета - файла с 
расширением .кд. На основе этого файла, в свою очередь, после 
обработки псевдокомпилятором создается исполнимый модуль с 
расширением Лго. Если файл с расширением Лгт уничтожен, то 
модифицировать существующий отчет с помощью команд 
СЯЕАТЕ, МСЮІРУ или в УЦ уже нельзя. В этом случае исходный 
программный модуль с расширением Лгд можно модифицировать 
с помощью текстового редактора. 

При разработке отчета или марки с помощью УЦ или 
командами СЯЕАТЕ/МООІРУ ЯЕРОЯТ (СЯЕАТЕ/МООІРУ ЕАВЕЬ) 
все заданные для печати параметры можно сохранить на диске 
в специальном файле формы печати с расширением .рг{, 
которому обычно присваивается то же имя, что и отчет или 
марка. Этот файл автоматически активизируется при очередной 
модификации или выполнении отчета (марки). Его также можно 
выбрать с помощью позиции ІІ$ег ргіпі {огт меню Ргіпі генера¬ 
тора отчетов (марок) в УЦ. Кроме того имя файла формы 
печати можно ввести в системную переменную _ р(огт или 
непосредственно задать значения соответствующих системных 
переменных, описание которых приводится ниже в данном 
разделе. 

Команда СЯЕАТЕ/МООІРУ І.АВЕІ. <имя файла отчета > /? 

передает управление на экран разработки (изменения) марки в 
УЦ и позволяет создать (изменить) файл разработки марки с 
расширением .ІЫ. Эта команда по своему синтаксису и выполне¬ 
нию аналогична предыдущей команде. Из файла разработки 
марки генерируется исходный программный модуль с расширени¬ 
ем -ІЬд, который затем трансформируется псевдокомпилятором 
в исполнимый объектный модуль с расширением ,ІЬо. В сШАЗЕ 
IV можно использовать файлы разработки отчета и марки, 
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созданные в сІВАЗЕ III + , которые преобразуются в формат 

4ВА5Е IV и сохраняются с расширением ЛхЪ и .ІЬЗ. 

Как уже указывалось, системные переменные позволяют 
управлять выходным потоком данных и их печатью. Некоторые 
из этих переменных уже встречались в тексте и примерах. 
Рассмотрим подробнее их функции. 

В число системных переменных входит группа, которая 
управляет выходным потоком, и группа управления печатью. 

Последняя включает подгруппы управления принтером, печатью 
документа в целом и печатью текста параграфа и пункта 

(абзаца). 

В группу управления выходным потоком входят системные 
переменные: _Ьох, _ радело, _рсоІпо, _ріогт, _рІепд*Ь, 

_рІіпепо, _р$расіпд и _іаЬ$. 

Для печати (подавления печати) рамки, заданной командами 
РЕНИЕ ВОХ или @...ТО, в зависимости от заданного условия 
нужно назначить переменной _Ьох соответстующее логическое 
выражение. С помощью этой переменной можно не толькб 
напечатать рамку, но и сделать, например, обрамление текста 
уголками. Для этого нужно прервать печать рамки, установив 
_Ьох я .р., затем напечатать текст и допечатать оставшуюся 
часть рамки, восстановив значение .Т. 

Пример: 

$ЕТ ТАІЖ ОРР 

ІІ$Е Оеіаі ОШК Иошег 

ОЕРІЫЕ ВОХ РВОМ 5 ТО 75 НЕІОНТ 10 ШЫЕ 

_Ьох ■ Л. 

77 5РАСЕ(60) АТ 10 
7 

Ш - 1 
5САН 

_Ьох - (Iпсі < 5 .Ой. ІпсІ > (ЛЕССОI)NТ() - 4)) 

77 Иотег АТ 7, йагѵапіе 
7 

ІпсІ - ІпсІ + 1 
ЕН05САМ 

77 БРАСЕ (60) АТ 5 
7 

В этой программе удаляется (заполняется пробелами) 
средняя часть верхней и нижней линии рамки и сама рамка 
выводится с разрывом по середине, в результате чего выведен- 
ные данные из файла БД с именем ЬеіаІ (номер и название 
детали) окружаются уголками. 

Назначение числового выражения переменной _радело я 
<выр.Н> используется для задания номера страницы первого 
печатаемого листа при печати комбинированных выходных 
документов. Кроме того, эту переменную можно использовать 
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для возвращения текущего номера страницы с целью выполнения 
на определенной странице заданных действий. В качестве 
начального значения можно задавать целые числа от 1 до 32767 
(по умолчанию 1). Текущий номер страницы определяется 
увеличением на единицу номера предыдущей страницы и зависит 
от значений переменных _рІелдіН и _рІілело. 

Не следует смешивать переменную __ радело с _рЬраде, 
устанавливающей номер страницы, с которой начинается печать 
документа. Значения системных переменных .радело, _рЬраде 
и _ рераде должны быть согласованы. При этом, значение 
переменной __ радело должно быть меньше или равно значению 
переменной _ рераде. Например, при установке значений 
.рЬраде = 3, __ рераде = 5 и _ радело = 10 печати не будет, 
так как текущий номер страницы (10) находится вне диапазона 
печатаемых страниц (с 3-й до 5-й). 

Пример: 

РК0СЕ01ЖЕ 2адо1оѵок 
РКІѴАТЕ «гар, _а1 ідптепі: 

_а1 ідптеп* = "СЕИТЕК" 

? радело РІСТІЖЕ "@Т 999 м , "-" 

? 

КЕТІШ . 

В этом примере расмотрена процедура для печати номера 
страницы в центре верхней части листа. 

Для установки номера колонки (между 0 и 255), с которой 
начинается вывод данных на принтер, в текущую строку экрана 
или в файл на диске используется назначение числового 
выражения переменной __ рсоіло = <выр.И>. Эту переменную 
можно также использовать для возвращения текущего номера 
колонки вывода информации, а также для повторной печати по 
уже напечатанному тексту, если предварительно задать _^гар 
= .Р., $ЕТ РКІИТЕР ОИ и установить значение .рсоіло меньше 
текущего. Если в этом случае установить . ^гар = .Т., то текст 
будет переписываться в буфер принтера без вывода на печать. 
Следует отметить, что выполняющая аналогичные действия 
функция РСОЦ) возвращает текущую позицию только головки 
принтера, а переменная _ рсоіло - текущую позицию выходного 
потока независимо от установки команды $ЕТ РКІЫТЕК. Действие 
переменной __рсоІло эквивалентно опции АТ команды ?/??. 

Пример: 

_игар = . Р. 

? "Пример правки текста" 

_рсо1по = _рсо1по - І_ЕМ("правки") 

?? КЕРИСАТЕС’Х", ЬЕИ("правки")) 

?? "Текст изменен" 

? 
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Выше уже упоминалось, что установки печати, включая 
значения системных переменных _рас!ѵапсе, _ радело, _рЬраде, 
_рсоріе$, _р<1гіѵег, _ ресосіе, ~.ре\есі, _ рераде, _рІепдіЬ, 

_рІоЙ$еі, _рріісЬ, _рдиаІйу, _р$сосІе І _р$ра$тд и _рѵѵаі^ 

можно сохранить при создании отчета в специальном файле с 
расширением .ргі (см. раздел 2.6) и впоследствии многократно 
использовать при печати однотипных отчетов. Активизация этого 
файла и считывание в оперативную память записанных в нем 
значений системных переменных выполняется с помощью 
назначения имени этого файла системной переменной _рІогт = 
"<имя файла формы печати >". Кроме того, эта переменная 
позволяет возвратить имя активного файла формы печати. Для 
установки полной длины выводимой страницы от 1 до 32767 
строк (по умолчанию 66) используется назначение числового 
выражения переменной _рІепдИі = <выр.И>. При этом верхний 
и нижний отступы для заголовка и подножия страницы и 
размещение текста на листе можно сформировать командой ОИ 
РАСЕ (более подробно об этой команде см. ниже в данном 
разделе). 

Для возвращения текущего номера строки выходного потока 
данных или назначения номера строки, с которой нужно 
выводить данные, используется переменная _рІіпепо = <выр.ІЧ>. 
Номер строки увеличивается на единицу после вывода предыду¬ 
щей строки. Эту переменную можно использовать для позицио¬ 
нирования головки принтера в диапазоне от 0 до _ рІепдіН - 1. 
В отличие от функции ркоѵ/() переменная _рІіпепо активна и 
при выключенном принтере (при выводе на экран отслеживают¬ 
ся его строки) и ее значение не может превышать длины 
страницы. Не следует смешивать данную переменную с функцией 
ЫНЕИОП, которая возвращает номер строки выполняемой 
программы. 

Для установки интервала печати между строками при выводе 
информации можно использовать назначение условных чисел 
переменной „1 рзрасіпд = 1/2/3, обозначающих: 1 - одинарный 

интервал (без пропуска строк - по умолчанию), 2 - двойной 
интервал (пропуск одной строки), 3 - тройной интервал 

(пропуск двух строк). Значение этой переменной влияет на 
высоту печатаемой рамки. Например, двойной интервал вдвое 
увеличивает заданную высоту. 

При вводе и выводе информации часто требуется очередную 
порцию вводить или выводить с заданной позиции (например, 
вводить с экрана табличные данные или выводить их на прин¬ 
тер). Для этого на линии разметки экрана в текстовом редакторе 
устанавливаются символы табуляции, позволяющие передвигать 
курсор навигационными клавишами по этим позициям. При 
выводе на принтер позиции табуляции играют роль колонок, с 
которых начинается печать очередной порции текста. Для 
установки позиций табуляции можно назначить список этих 



позиций в виде символьного выражения переменной _іаЬ$ = 
<выр.С>. Позиции в списке отделяются запятыми и располага¬ 
ются в возрастающем порядке. Например, _іаЬ$ = "5,25,44,65" 
устанавливает табуляцию на 5, 25, 44, 65 позициях. 

Можно послать символ табуляции, код А5СІІ которого 9, с 
помощью команд ?/?? и функции СНК(9), в результате чего 
головка принтера продвинется до следующего символа табуля¬ 
ции. Если установлено _жгар = .Т., то позиции табуляции, 

равные или большие, чем значение переменной _гтагдіп 
игнорируются. По умолчанию в текстовом редакторе сІВАЗЕ IV 
устанавливается табуляция по 8 позиций. Значение переменной 
_1аЬ$ также можно установить как значения параметра ТАВ5 в 
файле СопІід.сІЬ. 

К первой подгруппе группы системных переменных управле¬ 
ния печатью относятся: __ра<1ѵапсе, _ рсігіѵег, _ рІо№еі, _рріісЬ, 
_ряиаГгіу и _ржаіі 

К числу параметров управления печатью относится способ 
продвижения бумаги. Обычно на принтерах предусматриваются 
два способа продвижения бумаги: построчный и постраничный. 
В первом выполняется только построчное движение, а во втором 
- еще и автоматический переход к следующей странице после 
печати определенного количества строк. Назначение переменной 
__расІѵапсе= "РОКМРЕЕО"/"иЫЕРЕЕЬ5" ключевых слов позволяет 
задать способ продвижения бумаги: РОКМРЕЕР - постраничное 
продвижение (устанавливается по умолчанию), ЫИЕРЕЕ05 - 
построчное продвижение. В том и другом способе всегда 
отслеживается количество уже напечатанных строк. При выводе 
потока выходных данных с построчным продвижением бумаги 
перед вычислением количества строк, оставшихся до следующей 
страницы, проверяется, была ли команда на перевод страницы. 
Если эта команда инициирована, то вычисляется количество строк, 
которое требуется пропустить по формуле (__рІепдіЬ 
_рІіпепо). Данная ситуация возникает в следующих случаях: 

инициирована команда ЕІЕСТ РАСЕ при отсутствии обработчи¬ 
ка страницы, устанавливаемого командой ОИ РАСЕ; 

инициирована команда ЕІЕСТ РАСЕ и командой ОЫ РАСЕ 
установлен обработчик страницы, но номер текущей строки 
больше указанного в команде ОЫ РАСЕ; 

выполняемая программа печати достигает команд Р&ІИТІОВ 
или ЕНОРКШТЮВ и системная переменная _ре]есі вызывает 
перевод страницы. 

Если перевод страницы выполняется не в режиме потока 
данных, например, если выдается команда ЕІЕСТ или $ЕТ РЕѴІСЕ 
ТО РРІИТЕР и затем выполняется команда @...5АѴ...СЕТ, то для 
пропуска строк используется формула 

(— рІепдіЬ - МОО(РРО\Ѵ(), _рІепд*Н)). 

Посылка на принтер символа СНК(12) всегда устанавливает 
построчный режим продвижения бумаги. Системную переменную 
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_рас1ѵапсе целесообразно использовать при печати коротких 
страниц. В этом случае вместо установки длины страницы на 
принтере можно задать ее в переменной _рІепд*Ь, а в пере¬ 
менной,^ рас! ѵа псе - значение "ЫЫЕРЕЕОБ". 

Пример: 

РКІѴАТЕ _р1епдіЬ, _расіѵапсе 

_р1егПИ = 30 

_рагіѵапсе = "ИМЕРЕЕОЗ" 

ІІ5Е Зкіасі 
ЗСАИ 

00 Иак 1 ас! && Печать накладной 

ЕЗЕСТ && Перевод страницы в начало следующей накладной 

ЕЫОЗСАЫ 

СІ_05Е йАТАВАЗЕ 

В данном примере печатаются накладные с помощью 
процедуры Ыакіасі на страницах длиной по 30 строк. 

Как уже упоминалось, в принтерах различных типов исполь¬ 
зуются специфические наборы кодов символов. Для преобразова¬ 
ния посылаемого из ПК расширенного набора символов ІВМ, 
включая управляющие коды конкретного принтера, используется 
специальная программа - драйвер этого принтера. Например, 
драйвер интерпретирует посланные в принтер командами 
(кроме команды ???) символы, обеспечивающие печать различ¬ 
ными шрифтами: жирным, с подчеркиванием, наклонным и т.д. 

При установке сіВАБЕ IV можно назначить требуемый 
драйвер принтера, который будет использоваться по умолчанию. 
Его имя автоматически записывается в файл СопЛд.ЗЬ. Если 
используется другой принтер, то его драйвер можно назначить 
в программе или в командном режиме с помощью переменной 
_рс!гіѵег = "<имя файла драйвера принтера>". Такое назначе¬ 
ние активизирует (открывает) требуемый драйвер принтера, если 
он имеется на диске. Напомним, что если драйвер находится на 
диске и в директории, отличном от текущего, то перед именем 
надо указывать диск и маршрут по директориям. Расширение 
имени файла драйвера указывать не следует (допускается 
только расширение ,рг2). Переменная __рсІгіѵег позволяет также 
ѵ- возвратить имя текущего драйвера принтера. В примере, 
приведенном ниже, описывается программа для установки 
требуемого драйвера принтера в зависимости от его типа. 

Пример: 

Ѳ 10,20 5АУ "Выберите тип принтера" 6ЕТ Іір 
РІСТІЖЕ "ѲМ Ерзоп РХ-85, НР І_азег0е1:, Ргорг іпіег" , 

МЕ55А6Е "Просмотр типов - клавишей ПРОБЕЛ, выбор - клавишей Епіег" 

КЕАЭ 

00 САЗЕ 

(■АЗЕ *ір = "Ерзоп РХ-85" 

_рсігіѵег = "РХ85_1.рг2" 
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САБЕ *1р = "НР І-азегОеІ" 

_ргіг1ѵег = "НР1А5100.рг2" 

САБЕ 11р = "Ргоргіпіег" 

_рсіг1ѵег = ”ІЬтрго_1 .рг2" 

ОТНЕКѴІ5Е 

_ргігІѵег = "6ЕИЕКІС .рг2” 

ЕЫОСАБЕ 

Для установки сдвига печати слева от края страницы в 
диапазоне от 0 до 254 позиций (по умолчанию 0) используется 
назначение числового выражения переменной _рІо№еі = 
<выр.Ы>. Значение переменной _Ітагдіп отсчитывается от 
последней позиции, определенной значением _рІо№еі. Обычно 
эта переменная используется для сдвига печати всего документа, 
если он ложится не по центру на бумаге. Команда $ЕТ МАРСІИ 
устанавливает то же самое значение, что и переменная _ рІо№еі 
При этом изменение значения в команде вызывает соответствую¬ 
щее изменение значения переменной. 

Значения переменных _рІоК$еі и _Ітагдіп взаимно незави¬ 
симы. Например, если установлены значения переменных 
__рІойзе1 = 10, __Ітагдіп = 5, а также значение переменной, 
устанавливающей абзац _іп<1епі = 6, то при изменении значения 
переменной _рІоЙ5е1 остаются неизменными установки левой 
границы и абзаца относительно сдвига печати, назначенного 
переменной _рІоНзе1. 

Установка нескольких типоразмеров шрифта осуществляется 
посредством назначения ключевых слов переменной _ рріісЬ = 
"РІСА"/ 9Г ЕІПЕ Г Ѵ”СОНОЕН$ЕО ГГ / Г, ОЕРАІ)ІѴ Г (РІСА - 10 символов 
на дюйм, БИТЕ - 12 символов на дюйм, СОИРЕИЗЕО - примерно 
17.16 символов на дюйм, ОЕРАШ.Т - установленный на принтере). 
Кроме того, эта переменная, как и другие, позволяет определить 
(возвратить) текущее значение типоразмера шрифта. 

Принтеры обычно имеют режимы качественной и черновой 
печати текста. Для установки того или иного режима использует¬ 
ся назначение логического выражения переменной _ рс|иаІі1у = 

<логическое выражение>. При значении логического выражения 
.Т. устанавливается режим качественной печати текста, а при 
значении .Р. - черновой печати. При одновременной установке 
режима печати на принтере и с помощью переменной преиму¬ 
щество имеет назначение на принтере. 

Для установки режима ожидания перед печатью страницы 
используется назначение логического выражения переменной 
_ржаі1 = <логическое выражение>. При значении логического 
выражения .Т. устанавливается режим ожидания перед печатью 
страницы, а при значении .Р. печать выполняется непрерывно. 
Если для вывода на печать используется команда РКІЫТДОВ, то 
назначение переменной _ рѵѵаіі нужно делать перед этой 
командой. 
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Ко второй подгруппе группы управления печатью относятся 
системные переменные: . рЬраде, . рсоріез, . ресосіе, . реіесі, 
.рераде и . рзсосіе. Системные переменные этой подгруппы 
активизируются командой РКІИТЮВ. 

При печати выходных документов нередко требуется 
перепечатать одну или несколько страниц или продолжить печать 
отчета, прерванную из-за неполадок принтера или по другим 
причинам. Для задания первой печатаемой страницы (в диапазо¬ 
не от 1 до 32767, по умолчанию устанавливается 1) используется 
назначение числового выражения переменной .рЬраде = 
<выр.М>. Значение этой переменной должно быть меньше или 
равно значению переменной .рераде, которая устанавливает 
последнюю печатаемую страницу документа (также в диапазоне 
от 1 до 32767, по умолчанию устанавливается 32767) посредством 
назначения ей числового выражения: .рераде = <выр.И>. При 
этом текущий номер страницы (значение переменной .радело) 
должен быть больше или равен номеру первой печатаемой 
страницы и меньше или равен номеру последней печатаемой 
страницы. 

Для того чтобы перепечатать заданное количество страниц, 
назначают совместно значения переменным .рЬраде и .рераде. 
Следует отметить, что номера страниц в переменных .рЬраде, 
.рераде и .радело обозначают не их физические номера, а 
номера, печатаемые на странице. При этом первой физической 
странице в переменной .радело может быть присвоен любой 
номер, от которого начинается отсчет. При перепечатке страниц 
из пронумерованного текста нужно также задавать не физические 
номера перепечатываемых страниц, а их порядковые номера, 
соответствующие принятой нумерации страниц. 

Пример: 

зіесі = 1 

0 10,30 $АѴ "Печатать со страницы" СЕТ зіесі РІСТІЖЕ "999" 

КЕАО 

_рЬраде - зіесі 

00 0*сЬе1 

В этом фрагменте программы осуществляется запуск на 
продолжение печати прерванного отчета со страницы, номер 
которой вводится с клавиатуры. 

Установка числа печатаемых копий (от 1 до 32767, по 
умолчанию 1) осуществляется назначением числового выражения 
переменной .рсоріез= <выр.Ы>. Эту переменную можно 
использовать только в программах вместе с командами РКІМТЮВ 
и ЕНОРКІЫТЮВ, установив предварительно ее значение перед 
выполнением этих команд. 

Ниже приводится фрагмент программы для задания коли¬ 
чества печатаемых копий. 
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Пример: О 

псор = 1 

0 10,20 $АѴ "Число копий: " 6ЕТ псор РІСТІЖЕ "99" 

_рсоріез = псор 

КЕАЭ 

_рзсосІе = "{27}{38}{108}{49}{79}" 

Р1ШТ00В 

&& Команды печати 
_ресос!е = "{27}{69}" 

Еыоркіытаов 

Для формирования стиля печати на принтер направляются 
управляющие коды. Эти коды посылаются командами ?/??, ??? 
или посредством назначения переменным _ рзсосіе и _ ресосіе. 
Обычно команды \/ г Л используются для формирования стиля 
печати отдельных строк текста, команда ??? - для формирования 
стиля печати параграфов, а значения системных переменных 
_р$сосІе и _ ресосіе - для всего печатаемого материала. 
Поэтому их назначение часто выполняется в командном режиме 
перед началом печати. В программе значение переменной 
_р$сосІе назначается до выполнения команды РВІЫТЮВ, а 
значение переменной _ ресосіе - до выполнения команды 
ЕИОРВІИТІОВ. Управляющие коды, назначенные переменной 
_рзсосІе, посылаются на принтер командой РВІНТЮВ, а назна¬ 
ченные переменной _ ресосіе - командой ЕИОРРІНТЮВ. 

Переменным назначаются коды в виде символьных выраже¬ 
ний: _рзсос!е = <выр.С> и _ ресосіе = <выр.С>. В качестве 
кодов разрешаются числа от 0 до 255, а длина символьной 
строки не должна превышать 255 позиций. 

Установка перевода бумаги осуществляется посредством 
назначения ключевых слов переменной _ редесГ = "ВЕРОВЕ"/ 
"АРТЕВ"/"ВОТН"/"МОНЕ", где ВЕРОВЕ (по умолчанию) перево¬ 
дит лист перед печатью; АРТЕВ - после печати; ВОТН - до и 
после печати; НОЫЕ - не переводит лист. Эта переменная 
используется только в программах и помещается перед командой 
РВІИТЮВ. 

Не следует смешивать действие этой переменной с командой 
ЕІЕСТ, которая вызывает перевод листа на принтере в соответ¬ 
ствии с режимами продвижения бумаги, установленными в 
переменной _ расіѵапсе. 

К третьей подгруппе управления печатью относятся систем¬ 
ные переменные: _аІідптеп1, _іпс!епі, _1тагдіп, _гтагдіп и 
_ ѵѵгар. Эти переменные позволяют задать позиционирование 
печатаемого текста, величину отступа абзаца и границы печати 
текста. Прежде чем позиционировать текст, надо задать его 
границы с помощью переменных __ Ітагдіп и _гтагдіп. Назначе¬ 
ние числового выражения переменной _ Ітагдіп = <выр.Ы> 

8 - 6340 

/ 
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определяет на странице левую границу вывода информации 
командой ?, если _жгар = .1. в диапазоне от 0 до 254. 

Напомним, что действия переменных _Ітагдіп и _рІоН$е! 
различны. Значение последней переменной определяет расстоя¬ 
ние между левым краем бумаги до позиции, с которой начинает¬ 
ся печать (сдвиг печати), если _Ітагдіп. = 0. Значение 
_Ітагдіп определяет позицию печати относительно сдвига, 
задаваемого значением _ рІо№еі. 

Пример: 

ЗЕТ ТМК ОРР 

І^Е Оеіаі 0К0ЕК Иотег 

_игар = Л. 

_ітагд1п = 0 
? "Список деталей" 

? 

_1тагдіп = 15 
$САИ 

? Иотег + ” ", Кагѵапіе 

ЕН03САЫ 

Назначение числового выражения переменной _гтагдіп = 
<выр.И> устанавливает правую границу вывода информации 
командами \/\\, если _^гар = .Т. Правая граница представляет 
собой первую колонку после печати текста на строке. Минималь¬ 
ное значение этой переменной должно быть наибольшим из 
(_Ітагдіп + 1) и (_1тагдіп + _іпс!еп1 + 1), где значение 
_іп<1еп* может быть отрицательным числом. Максимальное 
значение переменной 255. После установки значений переменных 
_Ітагдіп и _гтагдіп можно форматировать выводимый текст 
внутри заданных границ. 

Переменная __ аіідптепі позволяет установить способ 
позиционирования текста, выводимого командами ?/??, по 
отношению к границам при условии, что _ілггар = .Т., посред¬ 
ством назначения ключевых слов: __ аіідптепі = "1.ЕРТ"/ 

"СЕМТЕК"/"ЛІОНТ", где І.ЕРТ выравнивает текст по левой 
границе; СЕИТЕК центрирует текст между левой и правой 
границами; КІСНТ выравнивает текст по правой границе. По 
умолчанию действует 1.ЕРТ. Не следует смешивать применение 
этой системной переменной с функциями поля @В, @1 и @.1, 
действующими аналогично, но по отношению к тексту в поле. 

Пример: 

_игар = Л. 

ЗЕТ РКШЕК 0И 

ЗЕТ ТАІ.К ОРР 

_а1 Ідпшепі = "СЕИТЕК" 

?? $ТР(_радепо,3,0),"-" 

ЗЕТ РІШТЕК ОРР 
_а1іпдпшепі = ЧЕРТ" 
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Переменная _іпс!еп1 позволяет установить величину отступа 
первой строки каждого нового параграфа, печатаемого командой 
?. Количество позиций отступа абзаца устанавливается назначе¬ 
нием переменной числового выражения: _іпсІеп1= <выр.Н> в 
диапазоне от отрицательного значения - (_Ітагдіп) до 
(_ гтагдіп _Ітапдіп - 1). Сумма (_іпсІеп1 + __Ітагдіп) 

должна быть меньше значения _гтагдіп. 

Выше при описании многих системных переменных упомина¬ 
лась переменная _жгар, которая устанавливает или отменяет в 
зависимости от своего значения вертикальную развертку текста 
командами ?/?? внутри заданных переменными _1тагдігк и 
„.гтагдіп границ. Значением этой переменной должно быть 
логическое выражение _жгар = <логическое выражение >. Если 
логическое значение .Т., то развертка выполняется, в противном 
случае - нет. Системные переменные _аІідптеп1, __іпс!епі, 
__Ітагдіп и _ гтагдіп действуют только при _жгар = .Т. 

При выводе на печать отчетов часто требуется на страницу 
выводить верхний и нижний колонтитулы. Это можно сделать с 
помощью команды (состояния) 

ОЫ РАСЕ [АТ ИЫЕ <выр.Ы> <команда> 

которая позволяет переключить процесс на выполнение действий, 
указанных в ней (обычно вызовом процедуры) при переходе на 
строку, заданную в опции АТ ЫИЕ в ходе выполнения команд 
?/?? ИЛИ ЕІЕСТ РАСЕ Команду ОИ РАСЕ иногда называют 
обработчиком страницы. Текущий номер строки содержится в 
системной переменной _рІіпепо. Если для создания отчета 
используется генератор отчетов, то команда ВЕРОВТ РОКМ при 
печати отчета автоматически активизирует обработчик страниц. 
Обработчик страниц может использоваться и с другими команда¬ 
ми вывода на печать, такими как РІ5РІ.АѴ или 5САНЕ. При 
определении номера строки следует учитывать, что в длину 
страницы входят высота верхнего и нижнего колонтитулов 
страницы. 

Процедура печати верхнего и нижнего колонтитулов должна 
начинаться командой ?, чтобы подавить перевод строки при 
активизации команды ОИ РАСЕ, а заканчиваться командой ЕІЕСТ 
РАСЕ. 

Все процедуры, которые обеспечивают вывод различных 
частей отчета (введения, итогов, подытогов и т.д.), должны 
начинаться командой ? и заканчиваться командой ??. В качестве 
команд, выполняемых в состоянии ОИ РАСЕ, запрещено 
использовать те же команды, что и при создании функции 
пользователя (см. разд. 3.6). 

Пример: 

(Ж РАСЕ АТ І-Ш 60 Э0 Раде_Ьгк 

ЗЕТ ТАІ-К ОРГ 
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ЗЕТ РКШЕК (Ж 

00 Меасіег && Печать верхнего колонтитула первой страницы 
$САИ АН 

? 01гі,Рап»,Нате 
Е N 03САН Е 

ЕОЕСТ РА6Е && Активизизация обработчика страницы 
Э0 Рооіег && Печать нихн. колонтитула послед, стр. 

ЗЕТ РКШЕК ОРР 

0И РА6Е && Деактивизация обработчика страницы 

ЗЕТ ТАЬК 0И 

КЕТІІКИ 

РК0СЕ01ІКЕ Неагіег 

ЕЗЕСТ РАСЕ && Переход на новую страницу 
? && Переход на вторую строку 

? "Список сотрудников” $ТѴ1_Е "В", 0АТЕ() АТ 70 
? 

? && Печать списка сотрудников с седьмой строки 

КЕТШ^ 

РК0СЕ01ЖЕ РооЕег 
? 

? && Печать нихнего колонтитула на 63 строке 

? "Учетный номер ” УсНпот 

?7 "Стр." АТ 70, ІЛКІМ($ТК(_радепо ,4,0)) 

КЕТІІКИ 

РЯ0СЕ01ІКЕ Раде Ьгк 
00 Рооіег 
ЭО Неасіег 
КЕТІІКИ 

Для обеспечения перевода бумаги на принтере к началу 
следующей страницы используется команда ЕІЕСТ. В зависимости 
от установки в системной переменной _рас!ѵапсе значения 
"РОКМРЕЕОЗ" или "ИЫЕРЕЕОЗ" на принтер посылается код А5СІІ 
12 или 10. После выполнения команды ЕІЕСТ значения функций 
РКО^О и РСОЦ) устанавливаются в нуль. Перед выполнением 
команды ЕІЕСТ для проверки состояния принтера можно 
использовать функцию РРІЫТЗТАТІІЗО, которая возвращает 
логическое значение .Т., если принтер включен. Эта функция 
возвращает состояние последнего установленного печатающего 
устройства независимо от способа установки, например команда¬ 
ми ЗЕТ РКІИТЕК ОИ, ЗЕТ РЕѴІСЕ ТО РРІЫТЕК или любой 
командой, содержащей предложение ТО РРІИТЕК, а также 
клавишами СЫ-Р. Следует отметить, что команда ЕЛЕСТ не 
изменяет значения системных переменных _ радело и _. рііпепо. 

Пример: 

00 ѴННЕ .Т. 

Ѳ 23,25 ЗАУ "Включите принтер” 

@ 24,25 $АѴ "Для запуска отчета на печать нахмите клавишу V" ; 

6ЕТ боЕоѵ "!" 
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КЕАй 

ІР .ИОТ. РаіНТ5ТАіиЗ( ) .ЛИО. боіоѵ = "ѴГ 
ЮОР 
ЕЫОІР 

ІР 6о*оѵ * "V" 

КЕРОКТ РОЛИ Касігу ТО РКІЫТ 
ЕЫОІР 
ЕХІТ 
ЕЫООО 

Более широкими возможностями обладает команда ЕІЕСТ 
РАСЕ, которая кроме перевода бумаги в начало страницы может 
вызывать обработчик страницы, если установлена команда ОЫ 
РАСЕ. В последнем случае команда ЕІЕСТ РАСЕ сравнивает 
текущую строку печати со строкой, указанной в команде ОЫ 
РАСЕ. 

Если текущий номер строки меньше этой величины, то 
команда ЕІЕСТ РАСЕ переводит головку принтера на соответству¬ 
ющее число строк, чтобы вызвать обработчик страницы. Если же 
текущий номер строки больше указанного в команде ОЫ РАСЕ 
или обработчик не установлен, то выполняются следующие 
действия. При установке команды 5ЕТ РКІЫТЕК ОЫ и _расІѵапсе 
= "РОВМРЕЕО" осуществляется перевод страницы. В случае 
_ ра Нѵапсе = "иЫЕРЕЕО$" на принтере переводится число строк, 
необходимое для перевода страницы. 

При выводе на другое устройство, например, на экран или 
в файл на диск (при установке 5ЕТ СОИЗОІ.Е или $ЕТ 
АНЕРНАТЕ), выполняется пропуск такого же числа строк. После 
выполнения команды ЕІЕСТ РАСЕ номер страницы в системной 
переменной _радепо увеличивается на единицу, а номер строки 
в __рІіпепо устанавливается в нуль. 

Выше указывалось, что для вывода данных на печать 
основной является команда ?/??. Однако перед печатью часто 
требуется выполнить подготовительные действия, например, 
перевести страницу, установить в начальное положение головку 
принтера и т.д. Для выполнения этих и других вспомогательных 
действий служит команда 

РКІЫТЮВ 
< команды > 

ЕЫОРКШТЮВ 

Эта команда состоит из двух частей. Первая из них РКІЫТЮВ 
активизирует параметры печати, которые определены системными 
переменными, и осуществляет следующие действия: 

посылает начальные коды печати, определенные системной 
переменной _р$со<1е5; 

переводит страницу, если системная переменная _ре|ес1 
имеет значение "ВЕРОВЕ" или "ВОТН"; 
устанавливает _рсоІпо в 0. 
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Вторая часть команды ЕЫОРКІНТЮВ вызывает следующие 
действия: 

посылает конечные коды печати, определенные системной 
переменной _ресосІе$; 

переводит страницу, если переменная _ре]есі установлена 

в "АРТЕК" или "ВОТН"; 

возвращает управление команде РКШТЮВ столько' раз, 
сколько это определено переменной _рсоріе$. 

Системные переменные обычно устанавливаются перед 
командой РКІЫТЮВ. При необходимости эти переменные 
переопределяются после команды ЕЫОРКІНТЮВ. 

Кроме указанных выше можно использовать все другие 
системные переменные, например, для остановки печати перед 
каждой страницей или для назначения формата печати. При 
разработке программ следует учесть, что команды РКІИТЮВ и 
ЕЫОРКІЫТЮВ не могут быть вложены сами в себя. 

Пример 1: 
у$е Ріо 

_ре іесѣ = "АРТЕК” 

ЗЕТ РКШ 
РКІІШОВ 

ОИ РА6Е АТ ШЕ _р1епд1Н-1 00 РадеЬгк 

ЗСАИ 

?? 01сі АТ 0, Рат АТ 8, Иате АТ 23 
? 

ЕЫОЗСАЫ 
ЕЫ0РК1ЫТ00В 
ЗЕТ РКШ ОРР 
КЕтикы 

РКОСЕОШІЕ РадеЬгк 
ЕОЕСТ РАСЕ 

7? йАТЕ() АТ 1, "Стр ." АТ 67,_радепо РІСТІЖЕ "999" АТ 73 
7 

КЕТІЖИ 
Пример 2: 

_рЬраде = 10 && Начальная страница печати 
_резес1: * "АРТЕК" && Перевод страницы после печати 
_рсоріез = 3 && Число копий 
КЕРОКТ РОКИ ОІсЬеі ТО РКІЫТ 

_рЬраде = 1 && Начальная страница по умолчанию 

_рсоріез = 1 && Число копий по умолчанию 

В последнем примере печатаются три копии с десятой 
страницы и до конца отчета и переводится страница после 
печати. Для печати отчета используется команда 

КЕРОКТ РОКМ <имя файла отчета>/? 

[<границы>] [\ѴНИЕ <условие>] 
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[РОК <условие>] [РІ.АШ] 

[НЕАОІНС <выр.С>] [ЫОЕЛЕСТ] 

[ТО РКІИТЕК/ТО РНЕ <имя файла>] [51ІММАРѴ] 

которая запускает программу печати отчета (файл отчета), 
созданную командой СКЕАТЕ/МОРІРУ КЕРОКТ. 

Эта программа (здесь не показана) включает команды 
РКІНТЮВ и ЕМОРКЖТЮВ. Программа печати выводит все или 
часть записей данных из активного файла БД или выборки, 
определенных заданными условиями отбора. Если в программе 
печати определены группы, активный файл БД должен быть 
проиндексирован или отсортирован по тем же полям, которые 
входят в выражение, задающее в отчете группу (см. разд. 2.6). 
Для одного файла БД может быть разработано несколько 
программ печати отчетов различного вида. Вызов списка всех 
программ печати, относящихся к активному файлу БД, выполняет¬ 
ся командой КЕРОКТ РОКМ ?. Отчет можно вывести на экран, 
принтер или. в текстовый файл на диск. Имя файла отчета 
(программы печати отчета), указанного в опции РОКМ, можно 
задавать с расширением .Ігд или Лго, с другим расширением, а 
также без расширения. В последних двух случаях выполняется 
поиск файла разработки отчета с заданным именем и, если он 
найден, то на его основе генерируется исходный программный 
файл с расширением .Ігд, который перед выполнением компили¬ 
руется в объектный модуль с расширением Лго. В данной 
команде можно также использовать файл разработки отчета, 
созданный в СІВА5Е III + . Этот файл преобразуется в формат 
СІВА5Е IV, далее выполняются описанные выше операции по его 
преобразованию, а в исходном файле сІВАБЕ 111+ расширение 
меняется на .ІгЗ. 

При работе в среде ЛВС команда КЕРОКТ РОКМ осуществля¬ 
ет автоматический захват файла БД перед печатью. Если другой 
пользователь пытается захватить файл, высвечивается сообщение 
Рііе і$ іп и$е Ьу апоіНег (Файл захвачен другим пользователем). 

Опция РІАІЫ при печати подавляет вывод нижнего и 
верхнего колонтитула на всех страницах, кроме первой. Опция 
НЕАРІИС выводит дополнительный заголовок на первой строке 
каждой страницы. Опции РІ.АІИ и НЕАРІЫО - взаимно исключаю¬ 
щие, причем РІ.АІИ имеет приоритет. 

Опция ИОБІЕСТ с ключевым словом ТО РКІЫТЕК подавляет 
перевод страницы перед печатью отчета и начинает печатать его 
на текущей странице. Если при создании отчета использовалась 
опция развертки текста по знаку точка с запятой (;) в символь¬ 
ных или полях Мето (состояние У/тар $етісоІоп$ ОЫ), то этот 
знак в тексте не печатается, а вызывает возврат каретки и 
перевод строки. 

Опция ТО РНЕ - выводит отчет в текстовый файл (.М). на 
устройство, установленное по умолчанию. Опция 51ІММАКѴ 
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подавляет вывод на экран всех строк отчета, кроме итогов и 
подытогов. 

Для печати марок используется аналогичная по структуре и 
выполнению команда 

І.АВЕІ. РОКМ <имя файла марок>/? [<границы>] [5АМРІ.Е] 
[УЖИЕ <условие>] [РОК <условие>] 

[ТО РКЖТЕК/ТО РНЕ < имя файла>] 

которая выводит на принтер или в файл на диск марку, 
созданную ранее командой СКЕАТЕ/МОРІРѴ І.АВЕІ.. Здесь 
отметим лишь, что имя файла марок можно задавать с расшире¬ 
ниями .ІЬд и .ІЬо. Опция 5АМР1.Е позволяет выполнить пробную 
печать одного ряда марок для контроля их расположения на 
листе бумаги. Вместо значений полей печатаются буквы X. 
Можно распечатать несколько таких образцов, отвечая V на 
предложение йо уои жапТ тоге $атрІе$? (Печатать еще 
образцы?), высвечиваемое в строке сообщений. При ответе N 
будут печататься марки с данными из файла БД. 

Текстовой файл отчета (или любой другой текстовой файл), 
записанный на диск, можно распечатать командой 

ТУРЕ <имя файла> [ТО РКІЫТЕК/ 

ТО РНЕ <имя файла>] [И1ШВЕК] 

Эта команда (без опций) выводит на экран текстовый файл, 
включающий только коды А5СІІ. Коды расширенного набора 
символов выводятся в виде графических символов. Имя файла 
должно включать расширение. 

Следует отметить, что данная команда не пригодна для 
просмотра файлов БД, так как эти файлы содержат символы, 
которые используются в сіВАБЕ IV для управления. Команда ТУРЕ 
не выводит открытые файлы, например программа не может 
включать команду ТУРЕ для вывода самое себя. 

Опция ТО РРШТЕР выводит текстовый файл на печать. Если 
драйвер принтера не поддерживает графические символы, то 
вместо них используются обычные, например, пробел, знак плюс 
и т.д. Ключевое слово ЫІІМВЕК дает возможность высвечивать 
или печатать номер строки. Это часто требуется при выводе 
программ. Номер строки соответствует строкам команд, а не 
высвечиваемым на экране строкам, так как команды могут 
продолжаться на нескольких строках. Если установлена команда 
5ЕТ НЕАРІИС ОЫ, то в начале каждой страницы высвечивается 
имя файла, текущая дата в формате, установленном командой 
$ЕТ 0А1Е и номер страницы. 

Команда 5ЕТ ОйОМЕТЕК ТО <выр.Н > изменяет интервал 
вывода номеров строк с 1 (задан по умолчанию) до 200. Эта 
команда также определяет интервал изменения значений счетчика 
записей во всех командах, которые выводят номера записей. 
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Команда $ЕТ ТАЕК ОРР подавляет вывод номера записи на 
экран. Опция ТО РІІ.Е позволяет записывать текстовой файл на 
диск, что дает возможность скопировать выводимый файл с 
другим именем. 

Описанные выше команды не обеспечивают вывода на печать 
графических символов. Исключение составляет команда 

РЕРІЫЕ ВОХ РВОМ <колонка> ТО <колонка> 

НЕІОНТ <выр.И> [ЛТ ПНЕ <номер строки>] 
[$ІИСІЕ/ООІІВІ.Е/<символы определения рамки>] 

с помощью которой печатается рамка вокруг текста. Для этого 
нужно определить позицию левой (после слова РКОМ) и правой 
(после слова ТО) сторон рамки, строку верха рамки и ее 
высоту. Если координаты рамки меньше текущих координат 
принтера (или отсутствует опция АТ ЫЫЕ), то рамка печатается 
на текущей строке принтера. 

Символы определения рамки указываются аналогично команде 
БЕТ ВОВРЕВ (см. разд. 3.2). По умолчанию печатается одинар¬ 
ная рамка. Опция НЕІОНТ определяет высоту рамки, а опция 
БІИСІ.Е (РОІІВІ.Е) - одинарную (двойную) линию рамки. Для 
печати рамки нужно установить значение .Т. системной перемен¬ 
ной __Ьох. 

Кроме команд собственно вывода на печать в командном 
языке сІВАБЕ IV предусмотрены команды установки (БЕТ-коман- 
ды) режимов вывода на печать информации, параметров печати 
и т.д. К ним относится команда БЕТ СІІВВЕЫСѴ ТО [<выр.С>], 
устанавливающая строку до 9 символов для обозначения валюты, 
и команда БЕТ СІІВВЕИСУ І.ЕРТ/ВІСНТ, определяющая размеще¬ 
ние слева или справа от числа строки символов валюты. 

Для назначения вывода заданного количества десятичных 
знаков чисел после запятой в диапазоне от 0 до 18 (по 
умолчанию установлено два знака) используется команда БЕТ 
РЕСІМА1.Б ТО <выр.И > . 

С помощью команды БЕТ 5ЕРАВАТОВ ТО [<выр.С>] можно 
задать отличающийся от принятого по умолчанию (запятая) 
разделитель трех десятичных порядков в целой части числа. 

Пример: 

5ЕТ 5ЕРАКАТ0К ТО 
•ЗЕТ РОІИТ ТО V 

Ѵаі = "100000.55" 

? Ѵаі РІСТІЖЕ "999,999.99" && Выводит 100.000,55 

В различных странах принят свой формат записи даты. Для 
установки различных форматов даты используется команда 

БЕТ РАТЕ [ТО] АМЕВІСАИ/АМБІ/ВВІТІБН/РВЕМСН/ОЕВМАИ/ 
ІТАИ АМ/МРАМ/ЫБА/МРУ/РМУ/УМР 

описание ключевых слов которой, приводится ниже. 
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АМЕКIСАЙ 

МН/ДА/ГГ 

АЙЗ I 

ГГ.ММ.дд 

ВКІТІ5Н/РКЕИСН 

ДА/ММ/ГГ 

6ЕКМАЙ 

дд.мм.гг 

ПАПАЙ 

ДД-ММ-ГГ 

0АРАЙ 

гг/мм/дд 

1)$А 

мм-дд-гг 

МОУ 

ММ/АД/ГГ 

ОМУ 

ДА/ММ/ГГ 

УМР 

ГГ/НИ/ДА 


Пример: 

Ѵаіе = СТОи ("30/07/89") 

5ЕТ ОАТЕ АЫ5І 

? Оаіе && Высвечивает 89.30.07 

ЗЕТ ОАТЕ 6ЕКМАЙ 

? Оаіе && Высвечивает 30.07.89 

Разделитель в дате можно изменить командой $ЕТ МАКК 
[<выр.С>] (по умолчанию установлен раделитель /). 

Пример: 

5ЕТ МАЙК ТО 

? ЭАТЕО && Высвечивает 10.08.89 

Обычно при выводе даты год представляется двумя послед¬ 
ними цифрами. По умолчанию устанавливается состояние 5ЕТ 
СЕИТШІѴ ОРР и числом века предполагается 19, которое в этом 
случае нельзя ни вводить, ни выводить в дате. Однако в 
вычислениях допускается получение даты за пределами двадца¬ 
того века, которая будет храниться в формате внутреннего 
представления даты. Если такая дата редактируется с помощью 
полноэкранных команд в состоянии $ЕТ СЕЫТІІКѴ ОРР, то число 
века изменяется на 19. Команда 5ЕТ СЕЫТІІКѴ ОЫ позволяет при 
вводе и выводе даты число века представлять четырьмя 
цифрами. 

Пример: 

ЗЕТ ОАТЕ 6ЕКМАЙ 

? РАТЕ() && Высвечивается, например, 30.07.89 

ЗЕТ СЕ НТІЖУ Ой 

7 0АТЕ() && Высвечивается 30.07.1989 

ЗЕТ СЕЙШУ ОРР 

В приведенных выше примерах использовались функции 
СТОО() для преобразования даты, представленной в виде 
символьного выражения в переменную типа даты, и ОАТЕ() для 
возвращения значения даты (более подробно о функциях 
обработки дат см. разд. 3.7). 
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Для установки левой границы начала печати (сдвиг печати) 
всего текста используется команда 

БЕТ МАК&Ш ТО <выр.И> 

которая задает размеры левого поля (по умолчанию равно 
нулю). Это поле также устанавливается системной переменной 
_рІоН$еі. Действующим будет последнее установленное коман¬ 
дой или переменной значение поля. Установка левого поля 
может быть также выполнена посредством присвоения значения 
соответствующему параметру в файле СопІід.сІЬ. Значение 
системной переменной _1тагдіп добавляется к значению, 
установленному командой БЕТ МАКСІЫ, если значение систем¬ 
ной переменной _жгар равно .Т. 

При выводе информации командами ?/•• поля данных 
автоматически разделяются пробелом. В некоторых случаях 
требуется сцеплять выводимые данные из нескольких полей. Это 
можно сделать различными способами, в частности установкой 
состояния $ЕТ 5РАСЕ ОРР (ОН задается по умолчанию). 

Пример: 

Раш = 'Сергеев' 

Иаш = 'Юрий' 

? Рагп.Маш && Выводит: Сергеев Юрий 

5ЕТ 5РАСЕ ОРР 

? Раш^аш && Выводит: СергеевЮрий 


3.6. РАЗРАБОТКА ПРИКЛАДНЫХ ПРОГРАММ 

В предыдущих разделах были описаны команды создания 
файлов БД, ввода и обновления в них данных, поиска и отбора 
данных, создания экранных форм ввода и вывода информации. 
После освоения этого материала можно приступить собственно 
к разработке прикладных программ. 

Прикладная программа представляет собой последователь¬ 
ность команд, постоянно хранящихся в файле на диске с 
расширением .ргд для исходных программ на языке СІВА5Е IV 
и с расширением .рг$ для программ на языке 501.. Напомним, 
что непосредственно выполняются исполнимые программные 
модули, которые формируются посредством псевдокомпиляции 
исходных программ. Для создания исходных программных 
файлов используются обычные текстовые редакторы, например 
встроенный редактор СІВА5Е IV, который вызывается командой 

МСЮІРѴ СОММАИй/РИЕ <имя файла> 

[Ѵ/ІИООѴѴ <имя окна>] 

Этот редактор используется для создания и модификации 
программных файлов и стандартных текстовых файлов А5СІІ. 
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Кроме того, он автоматически вызывается при разработке 
экранных форм, отчетов и марок. Если имя файла не задано 
или не найдено, то открывается экран для создания нового 
файла. Напомним общее правило при вызове файла. Если не 
указан диск и маршрут по директориям вызываемого файла, то 
предполагается текущий диск и директорий, а если не указано 
расширение файла, то для данной команды предполагается 
расширение .ргд. При использовании альтернативного синтаксиса 
команды МОРІРУ РНЕ расширение по умолчанию не действует 
и его надо задавать (если, конечно файл, создавался с 
расширением). По умолчанию в текстовом редакторе максималь¬ 
ная длина строки составляет 1024 символа (позиции) и всего 
можно создать 32000 строк. Опция >ѴІИОО\Ѵ позволяет вводить 
текстовой файл в заданное и ранее созданное окно. Если такого 
окна нет, то высвечивается сообщение Ѵ^іпсіож пате поі (оип4 
(Окно с заданным именем не найдено). Вместо встроенного 
редактора можно использовать любой текстовый редактор, 
установив его имя в файле СопІід.сІЬ. После изменения 
существующего файла предыдущая версия автоматически 
сохраняется на диске с тем же именем и расширением .Ьак. 
Для обеспечения функций по созданию и модификации файлов 
в текстовом редакторе сІВАБЕ IV имеется меню, которое 
описано в разд. 2.5 и 2.6. 

В программе команда записывается на одной или нескольких 
строках. Конец командной строки отмечается клавишей Епіег. 
При записи команды в несколько строк каждая из них, кроме 
последней, должна заканчиваться точкой с запятой. Созданный 
программный файл вызывается в оперативную память и затем 
выполняется командой ОО (более подробно об этой команде 
см. ниже в данном разделе). 

Как уже упоминалось, после загрузки в оперативную память 
исходного программного файла псевдокомпилятор сІВАЗЕ IV 
автоматически компилирует его в объектный исполняемый 
модуль, который затем выполняется. Этот модуль записывается 
на диск с расширением .сІЬо для обеспечения повторных 
запусков. Можно также откомпилировать исходную программу 
командой 

СОМРИЕ <имя файла> [ІШЫТІМЕ] 

которая считывает файл с исходной программой и создает 
выполнимый объектный модуль. 

Опция КУИТІМЕ выводит на печать команды, которые не 
разрешается использовать при выполнении программы с 
помощью модуля ІШЫТІМЕ, включающего в себя только 
интерпретатор и не содержащего интерфейса пользователя. 
Данная команда позволяет компилировать не только исходную 
программу с расширение .ргд, но и программы на языке $ОІ-, 
программные файлы экранных форм с расширением .іті, 
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отчетов (.(гд), марок (.ІЬд), запросов на отбор (.цЬе) и на 
обновление данных (.ирсі). После компиляции все эти файлы 
записываются с расширением .сІЬо. 

Прикладная программа обычно состоит из главной процеду¬ 
ры и вызываемых из нее процедур, например: 


<команды> 

00 Ргосі 
ЭО Ргос2 
ЭО РгосЗ 
КЕТІШ 

РК0СЕ01ЖЕ Ргосі 
<команды> 

ЯЕТУПЫ 

РР0СЕ01ІКЕ Ргос2 

<команды> 

йЕтиям 

РЯОСЕйиЯЕ РгосЗ 
<команды> 

КЕТІШ 


&& Начало главной процедуры 


&& Конец главной процедуры 
&& Начало Ргосі 

&& Конец Ргосі 
&& Начало Ргос2 

&& Конец Ргос2 
&8» Начало РгосЗ 

&& Конец РгосЗ 


Процедура представляет собой программный модуль, 
который выполняет определенную задачу. После ее выполнения 
управление передается в вызвавшую или главную процедуру. 
Процедура так же, как и программа, вызывается и выполняется 
командой 


ОО <имя программы>/<имя процедуры> 

[ѴПТН ссписок параметров>] 

Опция >АМТН передает в вызываемую процедуру параметры 
(до 64), которые представляют собой выражения, разрешенные 
в сІВАЗЕ IV. Если в выражении используется имя переменной, 
одинаковое с именем поля, то предполагается, что передается 
поле (поля имеют приоритет перед переменными). Для того 
чтобы передавалась переменная, нужно перед ее именем 
поставить М->. 

В любой процедуре можно вызывать другие процедуры, 
формируя, таким образом, вложенные структуры процедур. 
Следует избегать рекурсивного вызова процедур, т.е. вызова из 
процедуры этой же процедуры. Процедуры можно помещать 
вместе с главной процедурой или отдельно в специальный файл 
процедур, в котором может размещаться до 1170 процедур. 
Практическим ограничением на число процедур обычно выступа¬ 
ет емкость оперативной памяти, в которой размещается для 
выполнения как программный файл, так и файл процедур. В 
начале каждого объектного модуля помещается список проце¬ 
дур, которые в нем используются независимо от того, находятся 
ли они вместе с главной процедурой программы или в 
процедурном файле. В этот список первым входит и сама 
главная процедура под именем программного файла. Если 
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программный файл не имеет имени, то по умолчанию в 
качестве его процедурного имени назначается Маіп. 

Размещение процедур в программном файле обеспечивает 
более быстрое их выполнение, так как не требуется открывать 
и закрывать процедурный файл и считывать процедуры в 
оперативную память для выполнения. В то же время процеду¬ 
ры, которые выполняются только один раз, занимают оператив¬ 
ную память в течение всего времени выполнения прикладной 
программы. Поэтому целесообразно размещать часто выполняе¬ 
мые процедуры вместе с главной процедурой, а редко 
вызываемые - в процедурном файле. Перед выполнением 
команды РО вызова процедуры осуществляется поиск процеду¬ 
ры с заданным именем в следующей последовательности: в 
процедурном файле, если он открыт, отыскивается открытый 
объектный модуль с именем искомой процедуры; отыскивается 
и открывается закрытый объектный модуль с именем искомой 
процедуры; отыскивается и компилируется исходный програм¬ 
мный модуль с именем искомой процедуры; отыскивается и 
компилируется программа 5СН_ с расширением .рІ5 и именем 
искомой процедуры. Как видно из этой схемы поиска, в 
качестве процедуры можно также рассматривать и обычные 
программные модули, хранящиеся на диске. Это позволяет 
разработать гибкую схему вызова процедур с целью обеспече¬ 
ния оптимального использования оперативной памяти. Каждая 
процедура ограничивается объемом 64 Кбайт. Одновременно 
может быть открыто до 32 процедур, в число которых входят 
объектные модули разработанных ранее отчетов, марок, 
экранных форм и запросов. 

Если установлена команда $ЕТ ОЕѴЕЮРМЕЫТ ОЫ, то перед 
выполнением команды йО сравнивается время и дата создания 
исходного программного и объектного модулей с одним и тем 
же именем. Если исходный модуль создан позже, то он 
автоматически компилируется псевдокомпилятором и создается 
новый объектный модуль. После редактирования исходного 
модуля с помощью встроенного текстового редактора <ЗВА$Е IV, 
вызываемого командой МОЭІРѴ СОММАЫР или из УЦ, 
выполняется автоматическая компиляция перед его сохранением 
и новый объектный модуль замещает старый. 

Каждая процедура, размещаемая в файле процедур или в 
программном файле, должна начинаться с команды 

РКОСЕОиКЕ <имя процедуры > и завершаться командой 
КЕТШЖ [<выражение>/ТО МА5ТЕВ/ТО <имя процедуры>] 

Любая программа, а также и функция, определенная 
пользователем, должны завершаться командой ВЕТІІВИ, которая 
передает управление вызывающей программе, в УЦ или в 
командный режим. Если эта команда пропущена, то она 
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автоматически помещается в конце программы, процедуры или 
функции. При возврате управления процедурный файл закрыва¬ 
ется (если процедура вызывалась из него) и выполняется ко¬ 
манда в программе, следующая за вызвавшей процедуру ко¬ 
мандой. Опция ТО МА5ТЕК выполняет возврат в программу 
высшего уровня (в 005 или в сІВАЗЕ IV) в зависимости от 
того, откуда был осуществлен вызов. Опция ТО <имя процеду¬ 
ры > возвращает управление в активную процедуру с указанным 
именем. Команда КЕТІІКИ удаляет все переменные, которые 
были определены в процедуре как РКІѴАТЕ (переменные, 
определенные как РІІВЫС остаются без изменения, об опреде¬ 
лении переменных см. ниже), а также очищает значение 
(номер последней ошибки), возвращаемое функцией ЕККОК(). 

Для того чтобы обеспечить выход из программного файла 
в й05, используется команда ОШТ, которая закрывает все 
открытые файлы, завершает сеанс работы сІВАЗЕ IV и возвраща¬ 
ет управление операционной системе. Данная команда обеспечи¬ 
вает единственный надежный способ выхода из сІВАЗЕ IV. 
Выход из сІВАЗЕ IV путем перезагрузки ПК может повредить 
открытые файлы и вызвать потерю данных. 

Если установлено состояние ЗЕТ Е5САРЕ ОИ (задается по 
умолчанию), то выполнение программы можно приостановить 
нажатием клавиши Е$с, а поток выводимой на экран информа¬ 
ции клавишами СІтІ-5. Состояние ЗЕТ ЕЗСАРЕ ОИ также разре¬ 
шает занесение кода этих клавиш в буфер клавиатуры НІ5ТОКѴ. 
После приостановки программы высвечивается сообщение 

“ЧНТЕККиРТЕО*** 

СапсеІ, Ідпоге, Зи$репсП (С,І ог 3) 
позволяющее прекратить (СапсеІ), продолжить (Ідпоге), 
приостановить (ЗизрепсІ) выполнение программы. После 
приостановки управление передается в командный режим, 
откуда можно возобновить выполнение программы командой 
КЕЗІШЕ со следующей командной строки, в которой произошла 
приостановка. При установке состояния ЗЕТ ЕЗСАРЕ ОРГ 
аварийное прекращение выполнения программы возможно 
только перезапуском ПК. Команда ЗІІЗРЕНР позволяет приоста¬ 
новить выполнение программы. Эта команда в действительности 
и выполняется при выборе позиции Зи$репсІ после нажатия 
клавиши Е$с. Команда ЗІІЗРЕИО часто используется как средство 
отладки. После приостановки можно выполнить требуемые 
команды с клавиатуры или вызвать их из буфера клавиатуры 
НІЗТОКѴ и затем продолжить выполнение программы с 
помощью команды КЕЗІІМЕ. Созданные во время остановки 
программы переменные имеют статус РКІѴАТЕ. После приоста¬ 
новки программы можно не только выполнить команды с 
клавиатуры но и воспользоваться всеми возможностями УЦ, 
например для создания файлов БД, ввода и редактирования в 
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них данных, с использованием сервисных функций УЦ, а также 
для создания любых компонентов прикладной программы, 
включая экранные формы ввода и вывода информации, запросы 
и т.д. Из командного режима можно перейти в УЦ, набрав 
команду А$$І$Т или нажав функциональную клавишу Р2, за 
которой по умолчанию закреплена эта команда. Кроме того, 
выход на различные экраны УЦ можно осуществить из програм¬ 
мы соответствующими командами СКЕ АТЕ/МООI РѴ. Эти команды 
в основном были описаны в предыдущих разделах за исключе¬ 
нием команды 

СКЕАТЕ/МСЮІРѴ АРРиСАТЮИ <имя программы>/? 

которая передает управление на экран генератора прикладных 
программ. После входа в генератор с целью создания новой 
программы посредством выбора позиции <сгеаіе> представля¬ 
ется возможность разрабатывать ее самостоятельно, используя 
текстовый редактор (позиция СІВА5Е ргодгат в высвечиваемом 
меню) или с помощью генератора (позиция АррІісаіоіп5 
Сепегаіог) (более подробно см. разд. 2.6). Как и в других 
подобных командах, для создания новой или модификации 
существующей прикладной программы нужно указать ее имя. 
Можно также выбрать имя существующей программы из списка, 
высвечиваемого выполнением данной команды с опцией ?. 
Причём, если каталог открыт, то высвечиваемый список 
содержит имена программ из этого каталога, а при закрытом 
каталоге - имена всех таких программ, хранящихся на диске. 
Напомним, что прикладные программы, созданные с помощью 
генератора, имеют расширение .арр в отличие от обычных 
программ, которые по умолчанию сохраняются с расширением 
,ргд. При сохранении созданной прикладной программы ее имя 
автоматически заносится в открытый каталог, тогда как компо¬ 
ненты этой программы заносятся только в текущий директорий. 

Следует отметить, что при эксплуатации разработанной 
прикладной программы в ряде случаев нежелательно, чтобы 
конечный пользователь этой программы имел доступ к сред¬ 
ствам разработки прикладных программ. Для этого можно 
установить команду $ЕТ ОЕ5ІОЫ ОРР (по умолчанию ОЫ), 
которая выключает возможность перехода на экраны разработки 
файлов БД, отчетов, форм, марок, запросов и прикладных 
программ из командного режима или из УЦ. 

В ходе приостановки выполнения программы нельзя 
модифицировать эту же программу или какую-либо другую 
открытую программу или процедуру. В этом случае высвечива¬ 
ется сообщение Рііе аігеасіу орел (файл уже открыт). Модифи¬ 
кацию программы в ходе ее выполнения можно осуществить на 
экране отладчика, используя его опцию Есііі Выбор позиции 
СапсеІ в меню, высвечиваемом после нажатия клавиши Е$с, 
означает инициирование команды САИСЕІ-, в результате чего 
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прекращается выполнение всех программ и процедур, а 
программные файлы, кроме того, закрываются. Процедурный 
файл, из которого вызываются в программе процедуры, нужно 
закрыть командой СІ.05Е РКОСЕРІІКЕ. При попытке возвращения 
в программу посредством команды ЭО <имя программы > в 
режиме ввода команд с клавиатуры может не хватить памяти 
для повторного размещение программного модуля. В этом 
случае высвечивается меню для выполнения команд КЕ5ЦМЕ, 
САИСЕІ. и СНЯТ. Поэтому лучше возобновлять выполнение 
программы командой КЕ51ІМЕ, чем запускать ее заново. Можно 
также использовать команды САИСЕІ. и ОШТ. Если во время 
прерывания исполнения программы выполняется обновление 
файлов БД и затем с клавиатуры вводится команда КОІ-І.ВАСК 
(восстановить файл в исходное состояние, см. разд. 3.7), то 
команда КЕ51ІМЕ возобновляет выполнение программы на 
строке, следующей после команды ЕИО ТКАИ5АСТІОИ в 
программе. Команда КЕ$ІІМЕ также возобновляет работу после 
прерывания командой вызова отладчика ОЕВІІО (описание этой 
команды см. ниже в данном разделе). 

Рекомендуется перед командой КЕ51ІМЕ выполнять команду 
очистки экрана СІ.ЕА& (более подробно об этой команде см. 
разд. 3.4). Это гарантирует, что команды, введенные при 
остановке программы, не повлияют на последующий вывод 
информации на экран. 

Как уже упоминалось, командой РО в процедуру можно 
передавать из вызывающей программы и обратно параметры, 
которые в самой процедуре определяются командой 

РАКАМЕТЕК5 ссписок параметров> 

Эта команда должна быть первой исполняемой командой в 
теле процедуры. В качестве параметра в списке может быть 
любое допустимое выражение, определяющее переменную, в 
которую передаются данные из соответствующего параметра 
вызывающей программы. Если эта переменная не объявлена 
глобальной (РШП.ІС), то автоматически она имеет статус 
локальной (РВІѴАТЕ). После завершения работы процедуры и 
возвращения в вызывающую программу, локальные переменные 
процедуры уничтожаются. Типы переменных (выражений) в 
вызывающей программе и процедуре должны совпадать. Всего 
можно передать в процедуру до 50 параметров. 

Пример: 

РК0СЕ01ЖЕ РІозНагі 

РАКАМЕТЕК5 ЭПпа, ЗЬігіпа, А 

А = ЭПпа * $Мгіпа && А - площадь 

КЕТШМ 

00 РІозЬасі УІТН 6,4,А 

? А 
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Для передачи параметров, а также и для других целей, 
например, с целью хранения промежуточных результатов 
операций, ввода с клавиатуры данных и т.д., в процедурах 
часто используются переменные и их разновидность - элементы 
массивов. Как уже упоминалось, переменные могут быть 
локальными и глобальными. Переменные первого вида существу¬ 
ют только во время работы процедуры или программы, в 
которых они определены. После завершения работы процедуры 
(программы) эти переменные уничтожаются. Определение 
переменных как локальных выполняется командой 

РРІѴАТЕ <список переменных > 

/[АН [ЫКЕ/ЕХСЕРТ < шаблон >]] 

Локальные переменные могут иметь одинаковые имена с 
глобальными переменными, не влияя на последние, поскольку 
занимают в оперативной памяти разные участки. Между 
одноименными локальными переменными в разных процедурах 
также нет взаимодействия. Если в процедуре в качестве 
локальной объявляется системная переменная, которая по 
определению всегда глобальная, то создается копия этой 
переменной со статусом локальной и этой копии присваивается 
текущее значение системной переменной. Команда РРІѴАТЕ 
позволяет объявить со статусом локальной заданный список 
переменных, а также переменные, имена которых соответствуют 
заданному шаблону (опция АН ЫКЕ) или за исключением 
имен, указанных в шаблоне (опция ЕХСЕРТ). Напомним, что 
шаблон имени обычно включает общую часть имен и знаки 
замещения ? и *, первый из которых замещает один алфавит¬ 
но-цифровой символ, а второй - любое их число. В шаблон 
можно включать только одни знаки замещения. Это позволяет, 
например, знаком * задавать все имена, а несколькими знаками 
? имена соответствующей длины. 

Глобальные переменные можно использовать повсюду в 
программе и в вызываемых ею процедурах. Для объявления 
переменных и элементов массива глобальными используется 
команда 

РШиС ссписок переменных>/ 

[АРРАУ <список элементов массива > 

Кроме переменных в программах и процедурах можно 
использовать одно- или двумерные массивы. Каждый элемент 
массива представляет собой обычную переменную. Представле¬ 
ние переменных в виде массива позволяет значительно 
расширить диапазон применения переменных, а также, в ряде 
случаев, облегчить реализацию функций, присущих переменным. 
Перед использованием массивов сначала их надо объявить 
командой 
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РЕСІ.АРЕ <имя массива 1> 

[{<количество строк > г } {< количество колонок >}] 

{,<имя массива 2> 

[{<количество строк >,} {< количество колонок >}]...} 

В синтаксисе этой команды опции указываются фигурными 
скобками вместо обычно принятых квадратных. При записи 
команды в программе в квадратные скобки заключаются 
параметры (размерность) массива - число строк и столбцов. 
Если указано одно число, то массив одномерный. Формально 
двумерный массив с одним из параметров, равным единице, 
фактически является одномерным: ЬЕСІ-АРЕ [12,1] или йЕСІ-АРЕ 
[1,25]. 

Массив, объявленный в программном файле, по умолчанию 
имеет статус РРІѴАТЕ, а в командном режиме - РІІВИС. Имя 
массива может быть длиной до 10 символов и подчиняется 
правилам образования имен переменных и полей файлов БД - 
должно включать только буквенно-цифровые символы и символ 
подчеркивания, не содержать пробелов и начинаться с буквы. 

Нежелательно использовать имена из одной буквы, так как 
буквы от А до \ обозначают алиасы рабочих областей. Напри¬ 
мер, удобно использовать мнемонические имена, описывающие 
содержимое переменной, или начинать имя с буквы М. Все 
элементы только что объявленного массива содержат логическое 
значение ,Р.. Тип элемента массива, как и переменной, опреде¬ 
ляется типом введенных данных. 

Не рекомендуется массивам присваивать имена уже имею¬ 
щихся переменных, так как в этом случае никаких сообщений 
не выдается и результат обращения к таким массивам непред¬ 
сказуемый. Обращение к массиву может быть в форме 
обращения к одному элементу или ко всему массиву в целом. 
В первом случае использование в командах массива полностью 
аналогично использованию переменной. 

Вторая форма обращения применяется в командах типа 
СОРУ ТО АРРАУ или АРРЕЫО РРОМ АРРАУ. При ссылке на 
элементы массива, которые не существуют, высвечивается 
сообщение ВасІ аггау сІітеп5Іоп($) (ошибка в размерности), а 
при ссылке на несуществующий массив - N 0 ! ап аггау (массив 
не существует). 

Примеры: 

РЕСІ-АКЕ Маз [8,4] && Двумерный массив 

РЕСІ_АКЕ Мазі [10] && Одномерный массив 

5Т0КЕ {15/10/89} ТО ОаП [4,4].] 

После объявления массива в него можно вводить данные. 
Ввод данных в переменную или массив (или их изменение) 
можно осуществить различными способами: в программе, с 
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клавиатуры или из файла БД. Для ввода данных в переменную 
или элементы массива в программе используется команда 

5ТО&Е <выражение> ТО <список переменных> 

/< список элементов массива > 

или альтернативная форма 

<переменная>/<элемент массива> = <выражение> 

Команда 5ТОКЕ позволяет занести одно значение в несколь¬ 
ко переменных (элементов массива). Альтернативная форма 
короче и традиционно используется для числовых переменных, 
но значение заносится только в одну переменную. В сІВАБЕ IV, 
как и в других языках высокого уровня, значение числовой 
переменной можно прибавлять (вычитать) само к себе, а 
значение символьной переменной может быть сцеплено само с 
собой. 

Максимальное число переменных (элементов массива), кото¬ 
рые можно использовать в программе, определяется значениями 
параметров МѴВІ.К5ІІЕ и МѴМАХВІ_К5 файла СопКд.гіЬ. Если 
МѴВІ.К5І2Е = 50, а МѴМАХВІ_К5 = 10 (задаются по умолча¬ 
нию), то можно создать до 500 переменных. Имя каждого 
массива при объявлении занимает один участок памяти, 
отводимый под переменную. Под элементы массива память 
распределяется динамически. 

Во многих случаях удобно использовать одно имя для 
переменной и поля файла БД, например при засылке значений 
полей в соответствующие переменные с целью их промежуточ¬ 
ного хранения или обработки. 

В командах сІВАБЕ IV поле файла БД с именем, совпадаю¬ 
щим с именем переменной, имеет приоритет во всех операци¬ 
ях, кроме функции макроподстановки &. Как уже указывалось, 
для установления в этом случае приоритета переменной нужно 
впереди ее имени поставить символы М->, например, М->Рат. 

Примеры: 

5Т0ЯЕ .Р. ТО Раізе && Занесение в переменную Раізе значения .Р. 

5Т0ЯЕ 0 ТО а г Ь,с && Занесение значения 0 в переменные А, В и С 

Иеисіаіе = {31/10/89} 

Мх = 335 

После завершения работы программы и выхода в сІВАБЕ IV 
все переменные и массивы уничтожаются. Для сохранения их 
на диске с целью последующего использования применяется 
команда 

$АѴЕ ТО <имя файла > [АН ЫКЕ/ЕХСЕРТ < шаблон >] 

Эта команда записывает в файл на диске (по умолчанию 
с расширением .тет) все или часть (определяемую заданным 
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шаблоном), находящихся в текущий момент в оперативной 
памяти переменных и элементов массивов. 

Примеры: 

$АѴЕ ТО В:Мет && Сохраняет в файле Мет все 

* переменные и массивы из программы. 

8АѴЕ АН ИКЕ гі* ТО В:Мет && Сохраняет переменные 

* (массивы) с именами, начинающимися с буквы сі 

ЗАѴЕ АН ЕХСЕРТ ???Х* ТО Мет.ОН && Сохраняет переменные (массивы), 

* за исключением, тех, чьи имена содержат в 4-й позиции букву X 

Для восстановления в оперативной памяти сохраненных ранее 

переменных и элементов массивов используется команда 

КЕЗТОКЕ РКОМ <имя файла> [АООІТІѴЕ] 

По умолчанию предполагается, что файл переменных имеет 
расширение .тет. При этом все текущие значения восстанавли¬ 
ваемых переменных удаляются, если не указана опция 
АООІТІѴЕ. Если эта опция указана, то текущие значения 
сохраняются и к ним добавляются значения, считанные из файла 
на диске. Переменные восстанавливаются со статусом РВІѴАТЕ, 
если в программе они не были определены как РІІВЫС. Если 
же команда КЕ5ТОКЕ выполняется с клавиатуры, то все 
переменные восстановливаются со статусом РІІВЫС. 

В сіВАЗЕ IV можно использовать до 25 000 переменных. 
Фактически разрешенное число устанавливается как параметр в 
файле Сопіід.сІЬ (по умолчанию 500). Реальное число перемен¬ 
ных ограничивается объемом свободной оперативной памяти. 

Пример: 

Э0 Іпііѵаг 

КЕТІШ 

РК0СЕ01ЖЕ Іпііѵаг 

РІІВЫС Раде, Оіѵеі 

Раде = 1 

Оіѵеі = ’У’ 

КЕШКИ 

Для ускорения работы с внешними процедурами можно 
использовать команду 

ЗЕТ РКОСЕОІІКЕ ТО [<имя файла процедур >] 

которая открывает заданный файл процедур. Компилированные 
в сіВАЗЕ IV процедурные файлы имеют расширение .ргс, а 
некомпилированные - .ргд. Если не задано расширение проце¬ 
дурного файла, то предполагается, что это файл объектных 
(компилированных) модулей с расширением .сІЬо. В случае 
отсутствия и этого файла отыскивается файл с заданным именем 
среди некомпилированных программ, который перед выполнени¬ 
ем компилируется. Команды ЗЕТ РКОСЕОІІКЕ ТО <Епіег> или 
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СІ.05Е РКОСЕОІІКЕ закрывают текущий файл процедур. В 
каждый текущий момент может быть открыт только один файл 
процедур. 

Пример: 

<команды> && Главная процедура 

йО Ргосі 
<команды> 
йО Ргос2 
<команды> 

йетулы 

РКОСЕОДОЕ Ргосі 

0 15,0 $АѴ 'Система готова к работе' 

КЕТМИ 

РК0СЕ01ШЕ Ргос2 
0 10,0 С1.ЕАК 

0 15,10 $АУ 'Принтер не готов к работе' 

@ 17,10 $АѴ 'Включите принтер' 

КЕТІШ 

Для выполнения процедуры из файла процедур Рргосі.ргд 
нужно выполнить команды 

5ЕТ РК0СЕ01ЖЕ ТО Рргосі 

00 Ргосі 

СЮ5Е РК0СЕ01ЖЕ 

Кроме процедур, в программах сІВАЗЕ IV можно вызывать 
любые исполнимые двоичные модули. Существуют два способа 
выполнения внешних модулей. В первом способе нужно 
предварительно загрузить этот модуль в память командой 
І.ОАО <имя двоичного файла >. Одновременно можно загру¬ 
зить до 16 таких модулей (если нет ограничения на объем 
свободной оперативной памяти) размером до 32 000 байт. По 
умолчанию для этих модулей предполагается расширение .Ьіп 
(для определения количества и имен загруженных модулей 
можно использовать команду Ы5Т/ОІ5РІ.АѴ 5ТАТІІ5). Затем 
модуль запускается командой 

САН <имя модуля> [>ѴІТН ссписок выражений>] 

где имя модуля указывается без расширения. 

При вызове в двоичный модуль можно передать параметры, 
которые определены опцией Ѵ^ІТН, включающие символьные 
выражения, поля файла БД, переменные или элементы массива. 
Список может содержать до семи выражений. Все символьные 
переменные и выражения должны завершаться нулем 
(А5СІІ кодом нуля). При вызове модуля регистр С5 указывает 
на начало модуля в памяти, а регистры 05 и ВХ содержат 
адрес первого байта переменной, поля, элемента массива или 
символьного выражения. 
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Если двоичный модуль формируется из ассемблерной 
программы, то необходимо соблюдать следующие требования: 

первая исполнимая команда этого модуля должна разме¬ 
щаться со смещением нуль; 

вызываемый модуль не должен использовать память за 
пределами размеров самого модуля; 

в модуле нельзя изменять размеры переменных, передавае¬ 
мых в качестве аргументов командой САН; 

перед возвращением в сіВАЗЕ IV модуль должен восстано¬ 
вить регистры С5 и $5; 

возврат в сіВАЗЕ IV должен быть выполнен командой геі 

*аг. 

Вместо команды для запуска загруженного модуля можно 
использовать функцию 

САЩ<выр.С>,<выр.С> / <список имен переменных>) 

в которой первое символьное выражение в списке аргументов 
задает имя модуля (без расширения), а второе символьное 
выражение (или список переменных) позволяет передать и 
возвратить результат выполнения модуля как функции. При 
выполнении такой функции адрес первого аргумента загружается 
в регистры 05 и ВХ и управление передается в начало 
загруженного модуля для его выполнения. Переменные или 
элементы массивов, используемые в качестве передаваемых 
параметров, должны быть предварительно определены. Можно 
передавать до семи параметров. 

Модули, которые завершаются командой выхода в РОЗ, 
должны вызываться командой К1Ж/! <имя модуля или команды 
РО$>, которая реализует второй способ запуска внешних 
модулей (а также и выполнение команд РОЗ). В данном 
случае загрузку модуля в оперативную память осуществляет 
005. 

При выполнении команды КІІИ/І требуется дополнительная 
емкость оперативной памяти для файла Соттапсі.сот 005, а 
также соответствующая емкость памяти для выполнения модуля. 
Если памяти не хватает, то высвечивается сообщение Іп$и№сіепі 
тетогу (недостаточно памяти). 

Вызываемые модули и файл СоттапсІ.сот должны быть в 
текущем директории или же их маршрут по директориям 
следует указать в виде значения параметра сопнрес команды 
005, например, $е* соѵшрес = С:\СоттапсІ.сот. При 
выполнении команд 005, особенно в командном режиме, для 
сокращения записи лучше использовать альтернативную запись 
команды ШЖ - !. При этом надо иметь в виду, что програм¬ 
мные модули некоторых команд 005, например, анідпе и ргіпі, 
остаются в памяти после их выполнения, поэтому их лучше 
запускать до загрузки сіВАЗЕ IV. Перед загрузкой в память 
внешних модулей целесообразно оценить емкость свободной 
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оперативной памяти командой 0І5РІ.АѴ МЕМОКѴ, которая 
выводит информацию об использовании оперативной памяти 
(более подробно об этой команде см. разд. 3.2). Если памяти 
не хватает, то можно удалить из нее ряд неиспользуемых 
программных модулей, переменных, окон, экранных форм и т.д. 
Это можно сделать командами 

КЕІ.ЕА5Е <список переменных> 

или 

КЕІ.ЕА5Е [АН [ЫКЕ/ЕХСЕРТ < шаблон >] 

или 

КЕІ.ЕА$Е [МООШ.Е <список имен модулей >] 

/МЕЫІІ5 [<список имен горизонтальных меню>] 
/РОРІІР5 [<список имен вертикальных меню>] 
/ѴПЫОО>Ѵ5 [<список имен окон>] 

которые удаляют переменные, загруженные ассемблерные 
программы, горизонтальные и вертикальные меню, окна и 
освобождают занимаемую ими память. 

Команда КЕ1.ЕА5Е АН в режиме набора с клавиатуры 
удаляет все переменные (указанные в шаблоне с опцией ЫКЕ 
или за исключением указаных в шаблоне с опцией ЕХСЕРТ). 
Системные переменные не удаляются. При использовании этих 
команд в программе удаляются только локальные переменные, 
созданные в текущей программе или в программе нижнего 
уровня (переменные, созданные программами более высокого 
уровня, не удаляются). 

Команда &ЕІ.ЕА5Е МСЮШ-Е удаляет из памяти модуль, 
загруженный с помощью команды І.ОАО. 

Команда КЕІ.ЕА5Е МЕЫи$/РОРиР5/Ѵ/ІЫООѴ/5 удаляет с 
экрана и из памяти перечисленные в списке горизонтальные, 
вертикальные меню и окна. Команды ОЫ 5Е1.ЕСТІОИ, ОЫ РАО 
и СЖ 5ЕІЕСТІОЫ РОРЫР, связанные с меню, освобождаются 
перед удалением меню. Меню можно удалить только после их 
деактивизации. Если список в команде не указан, то удаляются 
все меню и окна. 

Примеры: 

КЕ5Т0КЕ РКОМ Мет && Удаляет все переменные, 

КЕІ-ЕА5Е АН ИКЕ т* && начинающиеся с буквы т 

ЭІЗРІ-АѴ МЕМОКѴ 

КЕ5Т0КЕ РКОМ && Удаляет все переменные, за исключением 

КЕ1.ЕАЗЕ АН ЕХСЕРТ ??Х* && тех, где в третьей позиции буква "Х ,г 

0І5РІ.АѴ МЕМОКѴ 

КЕЬЕАЗЕ Р0РІІР5 Есі , Асі , Оеі, Ех && Удаляет вертикальные меню с именами 

0ІЗРІ.АѴ МЕМОКѴ && Есі,Асі,0е1,Ех 
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Для прекращения выполнения любого программного файла 
используется команда САИСЕІ.. Одновременно закрываются все 
открытые программные файлы и управление возвращается в 
режим ввода команд с клавиатуры. Процедурные файлы не 
закрываются. Эта команда часто используется при отладке 
программ. 

Пример: 

ІР Меггог && Если возникла ошибка (значение 
САМСЕІ- && переменной Меггог = . Т.), то 
Е№ІР && выполнение программы прерывается 

В программах (и процедурах) кроме процедур можно 
вызывать функции, созданные пользователем. Функция строится 
подобно процедуре, но должна начинаться командой РІІИСТІОИ 
<имя функции >. Так же, как и процедура, функция завершает¬ 
ся командой КЕТІЛЖ < выражение >, которая служит для 
завершения функции и возврата в указанном выражении 
результата ее работы. Если функция не определяет никакого 
результата, то возвращается логическое значение .Р. В функцию, 
как и в процедуру, можно передавать параметры, которые 
в функции также должны быть определены командой 
РАКАМАТЕК5. В отличие от процедуры при вызове функции 
передаваемые параметры указываются в скобках после имени 
функции. Функции, определенные пользователями, упот¬ 
ребляются только вместе с командами, например в составе 
выражений, и вызываются по имени, указанном в команде 
РІРМСТІОИ. Имя функции подчиняется требованиям, установлен¬ 
ным для имен процедур и файлов (должно включать не более 
8 буквенно-цифровых символов и начинаться с буквы), и не 
должно совпадать с именами команд или системных функций. 
Перед выполнением функция должна быть откомпилирована и 
может храниться как отдельный программный файл (открытый 
или закрытый) с расширением .сІЬо или входить в состав 
процедурного файла (в этом случае для ее вызова нужно 
открыть процедурный файл командой 5ЕТ РКОСЕОІІКЕ) Имена 
функций, используемых в программном файле, содержатся 
вместе с процедурами в списке, размещаемом в начале 
объектного модуля этого файла. Поиск функции перед ее 
выполнением осуществляется аналогично процедурам. 

Пример: 

РІЖТІОИ $*па1од 
РАКАМЕТЕКЗ Мсепа,Мргос 

Мз-Ьоіт = (Мсепа*Мргос)+Мсепа 
КЕТІШ (Мзіоіт) 

Мргос = .10 
Мсепа = 100 

Тзѣоіт=$Іпа1од(Мсепа , Мргос )+0соз1 
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Если переменная М$іоіт определена как глобальная, то ее 
значение можно после вызова функции использовать повсюду 
в программе в качестве возвращенного функцией значения. В 
силу специфики выполнения функций, определенных пользовате¬ 
лями, в них запрещаетсяя использовать ряд команд сШАЗЕ IV: 


АРРЕЫО 
АРРЕЫО РКОМ 
АРРЕІ^Ю РКОМ АККАѴ 
АРРЕЫО МЕМО 
А55І5Т 

ВЕОІІМ ТКАЫЗАСТЮМ/ 

ЕЫЭ ТКАЫЗАСТІОЫ 
ВКОѴѴ5Е 
САЫСЕЬ 
СНАЫОЕ 

СІ-ЕАК АИ/РІЕЮ5 
СЮ5Е 

СІ.ОЗЕ АИЕКЫАТЕ 

С1_ОЗЕ РОКМАТ 

СІ.ОЗЕ РКОСЕОІІКЕ 

СОМРНЕ 

СОЫѴЕКТ 

СОРѴ 

СОРУ РНЕ 

СОРУ ІЫ0ЕХЕ5 

СОРУ МЕМО 

СОРУ ЗТКІІСТІІКЕ 

СОРУ 5ТКІІСТІ_)КЕ ЕХТЕЫОЕО 

СОРУ ТАО 

СОРУ ТО АККАУ 

СКЕАТЕ или МОЭІРУ ЗТКІІСТІЖЕ 

СКЕАТЕ РКОМ 

СКЕАТЕ ѴІЕ\Ѵ РКОМ ЕЫѴІКОММЕЫТ 

СКЕАТЕ/МООІРУ АРРЫСАТЮЫ 

СКЕАТЕ/МООІРУ І-АВЕІ. 

СКЕАТЕ/МООІРУ ОІІЕКУ/ѴІЕѴѴ 

СКЕАТЕ/МООІРУ КЕРОКТ 

СКЕАТЕ/МООІРУ ЗСКЕЕЫ 

ОЕВІЮ 

ОЕРІЫЕ ВАК 

ОЕРІЫЕ ВОХ 

ОЕРІЫЕ РАО 

ОЕРІЫЕ РОРІІР 

ОЕРІЫЕ ѴѴІЫООѴУ 

ОЕІ.ЕТЕ ТАО 

ОІК 


ЕОІТ 

ЕКА5Е или ОЕІ.ЕТЕ РНЕ 

ЕХРОКТ 

НЕІ.Р 

ІМРОКТ 

ІИОЕХ 

ІЫЗЕКТ 

ЮІЫ 

ЕАВЕЬ РОКМ 

ЮАО 

ЮСОІЯ 

МООІРУ СОММАЫО/РНЕ 
МОѴЕ ѴѴІЫООѴѴ 
ОЫ ЕККОК/Е5САРЕ/КЕУ 
ОЫ РАО 
ОІЧ РАСЕ 
ОЫ КЕАОЕККОК 
ОЫ 5ЕІЕСТІОЫ РАО 
ОЫ 5ЕІ_ЕСТЮЫ РОРІІР 
РАСК 

РКIІЧТЮВ/ЕЫОРКI ЫТЮВ 

РКОТЕСТ 

ОІЛТ 

КЕІЫОЕХ 

КЕРОКТ РОКМ 

КЕ5ТОКЕ 

КЕ5ТОКЕ МАСКОЗ 
КЕ5ТОКЕ ѴУІЫООѴУ 
КЕ51ІМЕ 
КОІПВАСК 
$АѴЕ 

5АѴЕ МАСКОЗ 

5АѴЕ ѴѴІЫООѴѴ 

ЗЕТ 

ЗОКТ 

зизРЕыо 

ТУРЕ 

ІІРОАТЕ 

2АР 
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Кроме этих команд, в функциях, определенных пользовате¬ 
лями, запрещено использовать функцию макроподстановки & и 
следующие команды $ЕТ: 

САТАЮ6 РСЖМАТ 

ОЕВІІС РКОСЕЭІЖЕ 

ЭЕѴІСЕ РЕІАТІОІЧ 

РІЕЮ5 

Удобство эксплуатации прикладных программ в настоящее 
время обычно обеспечивается созданием "дружественного" 
интерфейса пользователя, важным компонентом которого 
является создание меню прикладной задачи. Широкое распрос¬ 
транение получили меню горизонтального и вертикального типа 
и их сочетания. С помощью комбинации этих типов можно 
организовать вложенную древовидную структуру меню, в 
которой каждая позиция вышестоящего меню служит для 
раскрытия меню нижнего уровня, а позиция меню самого 
нижнего уровня выполняет определенные действия. 

Чтобы организовать в СІВА5Е IV систему меню, сначала надо 
определить его отдельные компоненты - меню вертикального 
и горизонтального типа. Для этого используются специальные 
команды, начинающиеся словом ОЕРІИЕ - определить. Опреде¬ 
ление горизонтального меню выполняется командой 

ОЕРІИЕ МЕИІІ <имя меню> [МЕ55АСЕ <выр.С>] 

Эта команда еще не создает горизонтальное меню, а только 
назначает ему имя и, если требуется, сообщение, которое будет 
высвечиваться в нижней строке экрана (строке сообщений). Для 
определения позиций горизонтального меню используется 
команда 

ОЕРІИЕ РАО <имя позиции> 

ОР <имя меню > РРОМРТ <выр.С> 

[АТ < строка >, < колонка >] [МЕ55АСЕ <вь;р.С>] 

котррая определяет одну позицию горизонтального меню. Для 
задания нескольких позиций данная команда повторяется 
соответствующее число раз. Имя позиции должно быть уникаль¬ 
ным и подчиняется обычным правилам написания имен полей 
и алиасов. В опции ОР указывается имя ранее определенного 
меню. 

Опция РВОМРТ определяет текст, высвечиваемый с заданной 
позиции горизонтального меню, определяемой опцией АТ, в 
которой указывается номер строки и колонки начала позиции. 
Данное меню условно называется горизонтальным в отличие от 
меню вертикального типа, однако команда по его созданию 
позволяет расположить позиции меню в любом месте экрана 


5КІР ТКАР 

ЗОЬ ѴІЕѴѴ 

$ТЕР Ѵ/ІЫЭОѴѴ 
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и, таким образом, создать любую форму, в том числе горизон¬ 
тального и вертикального типа. Если координаты в опции ДТ не 
задаются, то первая позиция меню помещается в левом 
верхнем углу экрана, а следующая через пробел от предыду¬ 
щей позиции на этой же строке. 

При размещении горизонтального меню в верхней строке 
экрана целесообразно установить состояние 5ЕТ 5СОКЕВОАІШ 
ОРР, чтобы не перекрывать меню информацией о состоянии 
клавиатуры. Передвижение по позициям меню осуществляется 
навигационными клавишами. 

Опция МЕ$$АСЕ позволяет каждой позиции меню назначить 
текст, который будет появляться в строке сообщений при 
выборе данной позиции. Это сообщение перекрывает сообще¬ 
ние, назначенное в команде РЕРІЫЕ МЕЫЦ 

Вертикальное меню определяется командой 

ОЕРІЫЕ РОРЦР <имя меню> 

РВОМ <строка 1>,<колонка 1> 

[ТО <строка 2>,<колонка 2>] 

[РКОМРТ РІЕЮ <имя поля>] 

/РКОМРТ РИЕ$ [ЫКЕ < шаблон >] 

/РРОМРТ $ткистіл*Е] 

[МЕ55АОЕ <выр.С>] 

которая устанавливает его имя (записывается по тем же 
правилам, что и для горизонтального меню) и координаты окна 
меню на экране. Опции РКОМ и ТО определяют координаты 
левого верхнего и правого нижнего углов окна меню. Если 
опция ТО опущена, то высота и ширина окна определяются 
автоматически в соответствии с количеством позиций и макси¬ 
мальной длиной поля позиции меню. Окно может располагаться 
в колонках 0-79 и строках 0-23 экрана (если строка состояния 
не используется). Минимальный размер окна - одна позиция 
экрана на пересечении колонки и строки. При выводе окна на 
экран оно закрывает любой текст, включая строку состояния. В 
каждый момент активным может быть только одно окно, 
поэтому разрешается определять несколько окон на одном 
месте экрана. Удаление окна вертикального меню с экрана 
выполняется с помощью его деактивизирования (более 
подробно об этом см. ниже в настоящем разделе). Данная 
команда позволяет определить не только вертикальное меню, 
но еще и списки (подробно о списках см. в разделе 2.9). 
Здесь напомним, что существуют списки трех типов: файлов, 
имен полей и значений полей. Для определения списка файлов 
используется опция РКОМРТ РІІ.Е5, которая высвечивает в 
позициях меню имена файлов из каталога в соответствии с 
заданным в опции ЫКЕ шаблоном. Без этой опции высвечивают¬ 
ся имена всех типов файлов текущего каталога. Опция РВОМРТ 
5ТКІІСТІІКЕ высвечивает в позициях меню все имена полей 
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активного файла БД или поля, указанные командой $ЕТ РІЕІ.05, 
если установлено состояние $ЕТ РІЕІ.05 ОИ. Опция РЛОМРТ 
РІЕЮ высвечивает в позициях меню содержимое указанного 
поля (кроме полей Мето) для всех записей файла БД. 
Напомним, что для файлов в других рабочих областях перед 
именем поля нужно помещать алиас файла БД. Опция МЕ55АСЕ 
позволяет высветить текстовое сообщение длиной 79 символов 
в нижней строке экрана после активизации меню. Это сообще¬ 
ние имеет приоритет перед командой $ЕТ МЕ55АСЕ ТО. 
Назначение текста и других атрибутов одной позиции ранее 
определенного вертикального меню осуществляется командой 

РЕРІИЕ ВАР <номер строки> ОР <имя меню> 

РКОМРТ <выр.С> 

[МЕ55АСЕ <выр.С>] [5КІР [РОК <условие>]] 

Чтобы определить нескольких позиций, нужно эту команду 
повторить соответствующее число раз. Позиции (строки) 
вертикального меню нумеруются целыми положительными 
числами сверху вниз. Позиции меню, которые не помещаются 
в ранее определенное окно, высвечиваются навигационными 
клавишами Вверх и Вниз (вертикальная прокрутка), а записыва¬ 
емый в позиции меню текст, который не помещается в окно, 
усекается справа. Текст позиции записывается в опции РРОМРТ. 
В опции МЕ55АСЕ записывается текстовое сообщение, высвечи¬ 
ваемое в нижней строке экрана после установки курсора на 
позицию меню. Опция 5КІР используется для пропуска позиции 
(высвечивание без выполнения действий), а опция РОР задает 
условие для ее пропуска. 

После того как определены позиции меню, обычно требует¬ 
ся назначить им определенные действия, которые будут 
выполняться при их выборе. Эти действия для позиций горизон¬ 
тального меню назначаются командой 

ОН 5ЕІ.ЕСТЮИ РАО <имя позиции горизонтального меню> 
ОР <имя горизонтального меню> [< команда >] 

которая выполняет заданную команду при выборе указанной 
позиции горизонтального меню. В качестве команды может 
использоваться любая команда СІВА5Е IV, в том числе команды 
вызова программ и процедур. Вызванные процедуры могут 
включать, например, такие функции, как МЕИЦП ИЛИ РАОО, 
для определения имени активного горизонтального меню и его 
выбранной позиции, чтобы выполнять соответствующие действия. 
Функция МЕИУО возвращает имя активного меню или пустую 
строку, если активного меню нет. Эта функция полезна при 
поиске имени активного меню в случае выхода из него, 
например, клавишей Р1 для просмотра справочной информации. 
Функция РАР() возвращает имя последней выбранной позиции 
горизонтального меню. 
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Напомним, что выбрать позицию меню - это значит устано¬ 
вить на эту позицию курсор и нажать клавишу Епіег. После 
выполнения команд, вызванных программ и процедур горизон¬ 
тальное меню опять становится доступным для последующего 
выбора. Если команда не указывается, то никаких действий при 
выборе позиции не выполняется. При организации системы 
меню часто требуется, чтобы при выборе позиции горизонталь¬ 
ного меню (которое обычно бывает основным) вызывалось 
вертикальное меню (прикрепленное к позиции горизонтального 
меню). Это можно сделать командой 

ОИ РАО <имя позиции горизонтального меню> 

ОР <имя горизонтального меню> 

[АСТІѴАТЕ РОРЦР <имя вертикального меню>] 

которая назначает вызов и активизацию вертикального меню при 
выборе позиции горизонтального меню, одновременно сохраняя 
на экране горизонтальное меню. Активизация меню означает, 
что навигационными клавишами можно передвигаться по 
позициям меню. Прикрепив к позициям горизонтального меню 
вертикальные меню, получаем систему меню, в которой при 
движении навигационными клавишами Вправо и Влево по 
позициям горизонтального меню вызываются прикрепленные к 
ним вертикальные меню. Если не указана опция АСТІѴАТЕ 
РОРЫР, то никаких действий при выборе позиций не выполняет¬ 
ся. Если позиции горизонтального меню раньше было назначено 
действие командой ОЫ 5Е1ЕСТЮИ РАО, то прикреплять 
вертикальное меню уже нельзя. 

Для назначения действий позициям вертикального меню 
используется команда 

ОИ 5ЕІ.ЕСТІОИ РОРІІР <имя позиции вертикального меню> 
/АН [< команда >] 

которая выполняет заданную команду или процедуру при 
выборе позиции вертикального меню. Если команда не указана, 
то ни одно действие при выборе позиции не выполняется. При 
использовании опции АП указанная команда выполняется для 
всех ранее определенных вертикальных меню. 

После выбора позиции начинается выполнение назначенных 
действий, а меню деактивизируется до завершения выполнения 
этих действий. Обычно выполняемая процедура содержит 
команду ОО СА$Е, позволяющую выполнить операции, соответ¬ 
ствующие выбранной позиции вертикального меню. Для 
идентификации этой позиции могут использоваться функции 
РОРУРП, РКОМРТО и ВАР(). 

Функция ВАК() возвращает номер последней выбранной 
позиции вертикального меню или списка. Эта функция возвраща¬ 
ет нуль, если в текущий момент нет активного меню или 
вообще не определено ни одно вертикальное меню или список, 
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а также, если была нажата клавиша Е$с, которая деактивизиро- 
вала меню. 

Функция РОРІІР() возвращает имя активного вертикального 
меню или списка. Если нет активного меню, то возвращается 
нулевая (нулевой длины) строка. 

Функция РКОМРТ() возвращает символьную строку, 
представляющую собой текст последней выбранной позиции 
горизонтального, вертикального меню или списка. Если нет 
активного меню, то возвращается нулевая строка. Для списка 
файлов возвращается полное имя файла, включающее маршрут 
по директориям и расширение прописными буквами, для 
списка полей - имя поля прописными буквами, а для списка 
значений поля - его содержимое из файла БД. 

Обычно для назначения позициям меню каких-либо действий 
используется выход на процедуру, в которой помещаются 
команды для выполнения этих действий. В такой процедуре 
чаще всего применяется команда 

ОО САЗЕ 

СА5Е < условие > 

< команды > 

[СА$Е < условие >] 

< команды > 

[ОТНЕК\ѴІ$Е] 

< команды > 

ЕЫ0СА5Е 

которая позволяет разветвить процесс выполнения команд в 
зависимости от выбранной позиции меню. Для этого за 
ключевым словом СА5Е помещается условие типа ВАКО = I і где 
I - номер выбранной позиции меню. При удовлетворении этого 
условия выполняются последующие команды до ключевых слов 
СА$Е, ЕЫ0СА5Е или ОТНЕК>АН$Е. Переход на команды после 
ключевого слова ОТНЕК>ѴІ5Е осуществляется в том случае, если 
условия всех ключевых слов СА$Е были оценены как ложные. 
После выполнения этих команд другие ключевые слова СА$Е в 
команде пропускаются и управление и передается на команду, 
следующую за словом ЕИ0СА5Е, которое завершает данную 
команду. Естественно, что данная команда имеет более широкое 
применение и с ключевым словом СА$Е может использоваться 
любое разрешенное логическое выражение. 

Можно формировать вложенные структуры этой команды, 
т.е. внутри команды после ключевого слова СА$Е помещать 
другую команду ОО СА5Е, а также любые другие команды 
ветвления и выполнения циклов, например ІР...ЕИОІГ, ОО 
ѴѴНИЕ...ЕЫООО и др 

Пример: 

РО СА$Е 
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САЗЕ Ѵаі > 1000 
<команды> 

САЗЕ Ѵаі > 100 
<команды> 

САЗЕ Ѵаі > 10 
<команды> 

ОТНЕКУІ5Е 

<команды> 

Е N ЭСАЗ Е 

Если требуется разветвить процесс только на два направле¬ 
ния, можно использовать команду 

ІР <условие> 

< команды > 

[ЕІ.5Е] 

< команды > 

ЕИРІР 

В случае оценки заданного условия как "Истина", т.е. при 
возвращении логического значения .Т. выполняются последующие 
команды. При оценке условия как "Ложь", т.е. в случае 
возвращения логического значения .Р. и наличия опции ЕІ.5Е, 

выполняются последующие команды, а без этой опции управле¬ 

ние передается на первую следующую за словом ЕРШІР 
команду. Данная команда позволяет формировать вложенные 
структуры любых команд ветвления, в том числе включать и 
команды ІР...ЕЫОІР 

При реализации операций, назначаемых позициям меню, 
нередко требуется организовать циклы повторяющихся действий, 
например организовать обработку файла БД и др. Это можно 
сделать с помощью ряда команд и их комбинаций. Одной из 
таких является команда 

РО \ѴНИЕ <условие> 

< команды > 

[ЕХІТ] 

< команды > 

[ЮОР] 

< команды > 

ЕИОРО 

которая обеспечивает повторение последовательности команд, 
заключенной между словами ОО \ѴНІ1.Е и ЕИРРО до тех пор, 
пока заданное условие истинно. Если встречается слово І.ООР, 
то управление передается в начало цикла команд, а при 
встрече слова ЕХІТ осуществляется выход из команды и 
управление передается на первую команду после слова ЕИРРО, 
завершающего данную команду. Обычно выход на слова І.ООР 
и ЕХІТ реализуется командами ветвления, например командой 
ІР...ЕЫОІР, 
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Действия, аналогичные предыдущей команде, можно 
выполнить командой 

$САИ [<границы>] [РОК <условие>] [УЖ НЕ <условие>] 
[< команды >] 

[ЮОР] 

[ЕХІТ] 

ЕНО$САЫ 

Эта команда также предназначена для организации повторя¬ 
ющихся циклов операций с помощью группы команд, располо¬ 
женных между словами $САИ и ЕИ05САЫ, но имеет более 
широкое применение, например при обработке активного файла 
БД, позволяет осуществлять отбор записей в соответствии с 
заданными границами и условием в опции РОК. 

Ключевые слова І.ООР и ЕХІТ в данной команде выполняют 
те же функции, что и в команде ОО УЖИ.Е...ЕИООО - первое 
передает управление в начало команды на повторение цикла, 
а второе обеспечивает выход на первую команду после 
завершающего слова ЕЫ05САЫ. Повторение циклов осуществля¬ 
ется до тех пор, пока условие, заданное опцией УЖНЕ, 
истинно или указатель записи (при обработке файла БД) 
достигает конца файла (последней записи, определенной 
границами). При этом передвижение указателя записей имеет 
следующие особенности. Указатель устанавливается в начало 
файла (на первую запись в индексе или в положение, 
определенное границами или опциями РОК и УЖ НЕ) и 
передвигается по отобранным записям. После завершения 
команды указатель остается на последней отобранной записи. 

Пример: 

115Е По 

5САЫ РОЙ .N01. ОІсІ = ’ОГ 

00 СНапде УIТН Иотег, Рат, N 31116 

ЕN^5САN 

При использовании команды ОО УЖ НЕ предыдущий пример 
выглядит так: 

1)$Е Ріо 

ЮСАТЕ РОЙ .N01. 016 = ’ОГ 

00 Ѵ/НИЕ .N01. Е0Р( ) 

00 СНапде ѴІТН N 011 ^ г Рат,N3^16 

^тиЕ 

Е N 000 

Предыдущие команды позволяют определить меню и 
атрибуты их позиций. Для того чтобы активизировать горизон¬ 
тальное и вертикальное меню (а также списки) используются 
команды 

АСТІѴАТЕ МЕНІІ <имя меню> [РАО <имя позиции >] и 


9 - 6340 
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ЛСТІУЛТЕ РОРІІР <имя меню> 


которые вызывают на экран предварительно определенные 
меню. Если указано имя позиции горизонтального меню, то 
курсор устанавливается на эту позицию. В противном случае 
курсор устанавливается на первую позицию меню. В каждый 
текущий момент активным является только последнее активизи¬ 
рованное меню. Если одно меню активизирует другое, то 
первое меню приостанавливает свое действие до тех пор, пока 
второе не будет деактивизировано. 

Деактивизация меню выполняется посредством активизации 
другого меню, нажатия клавиши Е$с или выполнения команд 
ОЕАСТІУАТЕ МЕИІІ и ОЕАСТІУАТЕ РОРІІР. Э ти команды 
деактивизируют активное в текущий момент горизонтальное или 
вертикальное меню, удаляют его с экрана, оставляя в памяти, 
и используются только в программах. Если для горизонтального 
меню установлена команда ОН РАО, то все связанные с ним 
вертикальные меню также деактивизируются. Команда деактиви¬ 
зации вертикального меню может использоваться в команде ОН 
5ЕІ.ЕСТІОН или в процедурах, вызываемых этой командой, что 
позволяет удалить меню с экрана после того, как осуществлены 
требуемые действия. 

После выполнения команд деактивизации меню управление 
передается на следующую строку программы. 

Для контроля внешнего вида разрабатываемых меню в 
программах можно использовать команды 

$НО\У МЕИІІ <имя горизонтального меню> 

[РАО симя позиции горизонтального меню>] и 

5НО\У РОРІІР <имя вертикального меню> 

которые высвечивают меню на экране без активизации. 

Команды по созданию меню должны располагаться в 
следующей последовательности: 

1. ОЕРІНЕ МЕИІІ, ОЕРІИЕ РОРІІР5 - определение меню; 

2. ОИ 5ЕІ.ЕСТІОН РАО, ОИ РАО, ОИ 5ЕІ.ЕСТІОН РОРІІР - 

назначение команд, выполняемых при выборе позиции; 

3. АСТІУАТЕ МЕИІІ, АСТІУАТЕ РОРІІР - активизация и 
высвечивание меню экране. 


Пример: 

ОЕРІНЕ МЕГШ Тез* 

ОЕРІЫЕ РАО Эіг ОР Тез* РКОМРТ "Директорий" АТ 0,0 
ОЕРІИЕ РАО Оес ОР Тез* РКОМРТ "Удалить меню" АТ 0,15 
ОИ 5ЕІ.ЕСТІ0Н РАО 01г ОР Тез* ОІК 
ОИ 5ЕІ.ЕСТІ0Н РАО Оес ОР Тез* ОЕАСТІѴАТЕ МЕНУ 
АСТІѴАТЕ МЕИІІ Тез* 
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В этом примере создается горизонтальное меню с именем 
Те$І с позициями "Директорий" и "Удалить меню". Первой из 
этих позиций назначается команда йІК, а второй - команда 
деактивизации меню. 


Пример: 

Мгіеі = .Р. 

ОЕРINЕ РОРЫР Ѵіем ГРОМ 1,1 ТО 6,22 

ОЕРІИЕ ВАК 1 ОР Ѵіе* РКОМРТ "Добавить запись" 

ОЕРІИЕ ВАК 2 ОР Ѵіеѵу РКОМРТ "Редактировать запись" 

ОЕРINЕ ВАК 3 ОР Ѵіеѵу РКОМРТ КЕРИСАТЕ , 20); 

ЗКІР 

ОЕРINЕ ВАК 4 ОР Ѵіе* РКОМРТ "Удалить запись"; 

ЗКІР РОК Мсіеі 

АСТІѴАТЕ РОРЧР Ѵіе* 

Здесь создается вертикальное меню Ѵіеѵѵ с позициями 
"Добавить запись", "Редактировать запись" и "Удалить запись". 
Последняя позиция пропускается, если переменная Мсіеі имеет 
логическое значение .Т. 

Перед последней позицией рисуется горизонтальная линия, 
которая является незадействованной (пропускаемой) позицией. 

Пример: 

ОК 5Е1ЕСТШ РОРІІР Ест 00 Ест 
РК0СЕ01ЖЕ Ест 
00 САЗЕ 

СА$Е ВАК() = 1 
АРРЕЫЭ В1.АКК 
ЕЭІТ ИЕХТ 1 
САЗЕ ВАК() = 2 
Е0ІТ 

САЗЕ ВАК() = 3 
ЭЕЬЕТЕ 
ЕИ0СА5Е 
КЕТІІКЫ 

В данном примере демонстрируется разветвление выполне¬ 
ния команд в зависимости от выбранной позиции меню, номер 
которой возвращается функцией ВА&(). 

Ниже приводятся примеры создания горизонтального 
меню с прикрепленными к каждой его позиции вертикальными 
меню. 


Пример: 

0ЕРІИЕ МЕІШ Маіп 
ОЕРІИЕ РАО Ѵіе* 0Р Маіп 
ОЕРІЫЕ РАО 6о 0Р Маіп 
ОЕРINЕ РАО Ргі 0Р Маіп 
ОЕРINЕ РАО ЕхіТ 0Р Маіп 


РКОМРТ "Добавить" АТ 0,0 

РКОМРТ "Перейти " АТ 0,11 

РКОМРТ "Печать " АТ 0,19 

РКОМРТ "Выход " АТ 0,27 
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Определяется горизонтальное меню и четыре его позиции 
с именами Ѵіеѵѵ, Со, Ргі и Ехі+. 

Пример: 

РЕРІИЕ РОРІІР Ѵіемрор РРОМ 1,1 ТО 6,18 
□ЕРINЕ РОРІІР борор ГРОМ 1,20 ТО 8,37 
ОЕРІЫЕ Р0Р0Р Ргі рор ГРОМ 1,40 ТО 4,60 
ОЕРШ РОРІІР ЕхИрор РРОМ 1,60 ТО 2,78 

Определяются четыре вертикальных меню с именами Ѵіеѵѵ, 
Со, Ргі и Ехіі. 

ОИ РАО Ѵіеѵѵ ОР Маіп АСТІѴАТЕ РОРЧР Ѵіеирор 

ОИ РАО 6о ОР Маіп АСТІѴАТЕ РОРІІР Оорор 

ОИ РАО Ргі ОР Маіп АСТІѴАТЕ РОРІІР Ргірор 

ОИ РАО ЕхП ОР Маіп АСТІѴАТЕ РОРІІР ЕхИрор 

Затем позициям горизонтального меню назначается активиза¬ 
ция вертикальных меню. 

ОЕРІИЕ Р0Р0Р Ѵіемрор РРОМ 1,1 ТО 6,22 

0ЕРINЕ ВАР 1 ОР Ѵіеирор РРОМРТ "Пустую запись" 

0ЕРINЕ ВАР 2 ОР Ѵіеирор РРОМРТ "В конец БД" 

ОЕРІЫЕ ВАР 3 ОР Ѵіеирор РРОМРТ "Из файла БД" 

После этого определяются позиции вертикального меню 
Ѵіеѵѵрор. Аналогично определяются другие вертикальные меню. 

АСТІѴАТЕ МЕМ Маіп 

Наконец, активизируется вертикальное меню, к позициям 
которого прикреплены вертикальные меню. 

Ниже приводится пример создания вертикального меню с 
двумя позициями. Затем это меню активизируется и после 
выбора первой позиции осуществляется выход в 005, а 
вторая позиция деактивизирут меню и передает управление в 
СІВА5Е IV (в УЦ или в командный режим). 

Пример: 

ЭЕРІМЕ РОРІІР ЕхП РРОМ 3,30 

РЕПМЕ ВАР 1 0Р ЕхН РРОМРТ "Выход в 005" 

йЕРINЕ ВАР 2 ОР ЕхП РРОМРТ "Выход в сіВАЗЕ IV" 

АСТІѴАТЕ РОРІІР ЕхП 
0Р 5ЕІ.ЕСТІ0Р Р0Р11Р ЕхП 00 Ех 
РР0СЕ0ЧРЕ Ех 
00 САЗЕ 

САЗЕ ВАР() = 1 
01ЛТ 

САЗЕ ВАР() = 2 
0ЕАСТІѴАТЕ Р0Р11Р 
Е N ОСАЗ Е 

Для создания удобства конечным пользователям, которые 
будут эксплуатировать разрабатываемую прикладную программу, 
обычно на экран выводится справочная информация о работе 
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программы, действиях пользователя и т.д. Примером такой 
информации служат сообщения, которые высвечиваются в строке 
сообщений при выборе позиций меню. В ряде случаев возника¬ 
ет необходимость вывода на экран больших объемов справочной 
информации. Это можно сделать различными способами, в 
частности командой 

ТЕХТ 

< текст > 

ЕИйТЕХТ 

которая выводит на экран (или на принтер, если установлено 
состояние 5ЕТ РКІНТЕВ ОИ) текст точно так, как он записан 
между словами ТЕХТ и ЕИОТЕХТ. Символ & в тексте интерпре¬ 
тируется как обычный символ, а не как функция макроподста¬ 
новки. 

В гл. 2 было описано распространенное средство обеспече¬ 
ния удобства работы пользователя - создание и использование 
макроопределений, представляющих собой имитацию последова¬ 
тельности нажатий клавиш на клавиатуре. В программе можно 
предусмотреть выход в УЦ для создания макроопределения. 
После создания макроопределения для его повторного выполне¬ 
ния обычно макроопределение записывают в библиотеку на 
диске. Если предполагается использовать созданное макроопре¬ 
деление при эксплуатации разрабатываемой прикладной програм¬ 
мы, то в ряде случаев полезно записать его в собственный 
библиотечный файл макроопределений. Такую операцию 
выполняет команда 5АѴЕ МАСК05 ТО <имя файла макроопре¬ 
делений >, которая записывает созданное макроопределение в 
библиотечный файл на диске с расширением .кеу. Можно задать 
другое расширение, указывая его затем при загрузке файла 
библиотеки в оперативную память перед выполнением макрооп¬ 
ределения, осуществляемом командой КЕ5ТОКЕ МАСІЮ5. 
Напомним, что в качестве имен макроопределений могут 
использоваться комбинации клавиш от АІІ-Р1 до АІ1-Р9 и АІІ-Р1 0 
с последующей буквой от А до 2. Таким образом, всего 
можно задать 35 уникальных имен макроопределений. В каждый 
библиотечный файл можно записать от 1 до 35 макроопределе¬ 
ний. 

Выполнение загруженного в память макроопределения 
осуществляется командой РІ.АѴ МАСКО <имя макроопределе¬ 
ния >. Имя макроопределения подчиняется правилам образова¬ 
ния имен полей файла БД и переменных (может состоять из 
десяти буквенно-цифровых символов, начинаться с буквы и не 
должно содержать пробела). Запуск команды выполнения 
макроопределения в программе отличается от запуска в 
командном режиме. В последнем случае команда запускается 
на выполнение сразу после нажатия клавиши Епіег, а в первом 
только после инициирования другой команды. Поэтому несколь- 
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ко последовательно записанных в программе команд РІ.АѴ 
МАСКО выполняются в обратной последовательности: первой 
выполняется последняя записанная команда, второй - предпос¬ 
ледняя и т.д. 

Командный язык СІВА5Е IV включает достаточно средств для 
обеспечения качественной отладки создаваемых прикладных 
программ. Одним из таких средств является отладчик программ, 
вызываемый командой 

ОЕВІІС <имя файла>/<имя процедуры> 

[>ѴІТН ссписок параметров>] 

Эта команда, как и команда ОО, выполняет программный 
или процедурный модуль, но в среде отладчика, имеющего 
свой экран. Экран отладчика содержит четыре окна: для запуска 
программы (процедуры) с любой точки и просмотра команд 
при их выполнении (окно отладки), редактирования програм¬ 
мы (окно редактирования), установки точек прерывания 
выполнения программы (окно прерываний) и вывода результа¬ 
тов раскрытия выражений при выполнении команд (окно 
результатов). В окне отладки, находящемся в нижней части 
экрана, высвечивается текущая рабочая область, имя файла БД, 
имя программы и процедуры, номер записи файла БД, номер 
строки программы (процедуры), главный (управляющий) 
индекс и приглашение АСТІОИ для ввода команды в ходе 
процесса отладки. Переход к этому приглашению выполняется 
клавишами Е$с или СігІ-ЕпсІ из любого места экрана отладчика. 
Команды задаются условными буквами, описание которых в 
любой момент можно высветить в правой верхней части экрана 
при нажатии функциональной клавиши Р1 вызова справочной 
информации. Ниже приводится перечень условных букв и 
выполняемых ими действий: 

Е - вызывает окно редактирования программы с текстовым 
редактором СІВА5Е IV. После редактирования нужно сохранить 
программный файл, чтобы избежать потери сделанных измене¬ 
ний. Следует отметить, что после возвращения в отладчик 
продолжается выполнение старого программного файла. Для 
запуска отредактированного программного файла нужно снова 
инициировать отладчик, при этом корректно завершив предыду¬ 
щий сеанс работы с отладчиком, т.е. буквой О в приглашении 
АСТІОИ; 

В - активизирует окно прерываний, находящееся с правой 
стороны в середине экрана. В это окно можно ввести с 
клавиатуры несколько точек прерывания выполнения программы 
в виде условий, которые проверяются после выполнения каждой 
командной строки. Если хотя бы одно из этих условий выполня¬ 
ется (возвращается логическое значение .Т.), то программа 
приостанавливается и высвечивается экран отладчика; 
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О - активизирует окно результатов, находящееся в левой 
стороне средней части экрана. В каждую строку этого окна 
можно ввести с клавиатуры любое выражение, после чего 
справа высвечивается его результат, например значение 
переменной, поля и т.д.; 

I. - определяет, какую следующую строку программы нужно 
выполнить; 

N - выполняет следующую за текущей команду в програм¬ 
ме и передает управление на приглашение АСТЮЫ. Если в 
текущей программе (процедуре) командой РО вызывается 
другая процедура, то она выполняется вне среды отладчика, 
хотя точки прерывания остаются в силе. Если перед буквой N 
указать число, то перед выходом на приглашение АСТЮЫ 
будет выполнено заданное число команд; 

Р - высвечивает трассировку выполняемой программы, 
включая имя текущей программы, процедуры и номер выполня¬ 
емой строки; 

О - осуществляет выход из отладчика и прекращение 
выполнения программы; 

В - запускает программу на выполнение до точки прерыва¬ 
ния или появления ошибки; 

$ - выполняет следующую команду, после чего управление 
передается на приглашение АСТЮЫ. Если перед буквой $ 
указать число, то перед выходом на приглашение АСТЮЫ 
будет выполнено заданное число команд. В отличие от буквы 
N здесь процедуры, вызываемые из текущей программы, 
выполняются в среде отладчика; 

X - осуществляет выход из программы и передает управле¬ 
ние в командный режим, в котором можно выполнить любые 
команды. Возврат в отладчик осуществляется командой &Е51ІМЕ. 
Из режима ввода команд с клавиатуры можно также войти в 
УЦ клавишей Р2 или командой А55І5Т и после выполнения 
требуемых операций вернуться обратно с помощью позиции Ехіі 
іо сіоі рготрі меню Ехіі или клавишей Е$с. 

Нажатие клавиши Епіег в приглашении АСТЮЫ вызывает 
выполнение операций 1$ или 1Ы в зависимости от того, какая 
из команд $ или Ы последний раз была выполнена. По 
умолчанию выполняется команда 15. Нажатие клавиши Р1 в 
любом месте экрана отладчика высвечивает, а при повторном 
нажатии удаляет панель со справочной информацией о выполня¬ 
емых приглашением АСТЮЫ командах. Нажатие клавиши Р9 
удаляет окна отладчика с экрана и высвечивает информацию, 
которая была скрыта экраном отладчика. 

Опция >ѴІТН позволяет передать в отлаживаемую программу 
параметры, как и в команде РО. Список параметров может 
содержать любые разрешенные в сІВАЗЕ IV выражения. Однако 
отлаживаемая программа в среде отладчика может принять не 
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более восьми констант, определяющих имена файлов. Число 
передаваемых переменных не ограничено. 

Помимо отладчика для определения имени программы или 
процедуры, в которой произошла ошибка, можно использовать 
функцию РКОСКАММ(). Эта функция возвращает имя програм¬ 
мы или процедуры (без расширения), а не файла процедур. 
В командном режиме эта функция действует только во время 
приостановки выполнения программы. Например, в программу 
можно включить такую команду локализации ошибки: 

ОЫ ЕККОК ? "Ошибка в " + РКОСКАМ() +; 

"Строка " + $ЩІТКІМ(иЫЕНО())) 

В число средств отладки программ также входит команда 
$ЕТ ТВАР ОИ (ОРР - по умолчанию), которая устанавливает 
состояние, автоматически вызывающее отладчик при обнаруже¬ 
нии в программе ошибки. Программа приостанавливается на 
строке, вызвавшей ошибочную ситуацию. Кроме того, в этом 
состоянии в любой момент можно вызвать отладчик клавишей 
Е$с. Следует отметить исключительную полезность команды $ЕТ 
ТВАР при отладке сложных программ. Опыт отладки программ 
на языке сІВАЗЕ IV показывает, что при возникновении ошибоч¬ 
ной ситуации нередко портятся открытые файлы и возникают 
другие непредсказуемые эффекты. Команда $ЕТ ТВАР вылавли¬ 
вает ошибку и, по существу, локализует ее, не давая послед¬ 
ствиям ошибки распространится на данные и программу. Из 
опыта отладки программ можно также порекомендовать не 
оставлять без надобности открытыми файлы и немедленно 
закрывать их после окончания работы с ними. Если одновремен¬ 
но установлено состояние ОЫ ЕВВОВ, то оно имеет приоритет 
перед ОИ ТВАР и при обнаружении ошибочной ситуации 
выполняется обработка этой ситуации командой ОЫ ЕВВОВ. В 
том случае, когда не установлено ни состояние ОМ ЕВВОВ и ни 
$ЕТ ТВАР ОЫ, ошибочная ситуация вызывает приостановку 
программы и высвечивается такое же меню, как и при нажатии 
клавиши Е$с, предлагающее прекратить выполнение программы 
(С), игнорировать ошибку (I), приостановить программу с 
выходом в командный режим ($). Напомним, что возврат из 
этого режима на продолжение программы осуществляется 
командой КЕ51ШЕ. 

Весьма полезной при отладке программ является команда 
$ЕТ ЕСНО ОЫ (ОРР - по умолчанию), выводящая на экран 
(или принтер) выполняемые команды (в программах или в 
командном режиме). При работе в среде отладчика данная 
команда позволяет наблюдать выполнение всех отладочных 
операций, включая выполнение команд программы. Однако 
высвечивание этих операций в ходе отладки на экране может 
помешать выводу другой информации, например меню, 
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экранных форм, данных из файлов БД и т.д. В этом еду чае 
можно направить информацию об отладочных операциях 
на принтер, если установить состояния ЗЕТ ОЕВІІС ОИ 
(ОРР задается по умолчанию) и ЗЕТ РВІИТЕВ ОЫ. Команда ЗЕТ 
ЕСНО ОИ позволяет высветить только выполняемые команды, 
но не их результаты. Для высвечивания результатов служит 
команда ЗЕТ ТАІ.К ОИ (устанавливается по умолчанию), которая 
позволяет выводить номера записей файлов БД, значения 

переменных, результаты выполнения команд АРРЕЫй РВОМ, 
СОРУ, РАСК, ЗТОКЕ и ЗІІМ. Если установлено состояние ЗЕТ 

ТАІ.К ОРР, то не выводятся ни результаты операций, ни 

сообщения об ошибках. Если требуется результаты направить на 
принтер, то как и для информации об отладочных операциях 
надо установить команды ЗЕТ ОЕВІІС ОИ и ЗЕТ РВІЫТЕК ОИ. 

В отладчике предусмотрены различные команды для 

организации процесса отладки, в том числе для обеспечения 
различных режимов выполнения программы - по одной строке, 
несколько командных строк, до точки прерывания и т.д. Режим 
выполнения программы по одной строке помимо отладчика 
можно также установить командой ЗЕТ 5ТЕР ОИ (ОРР задается 
по умолчанию). При этом высвечивается результат выполнения 
командной строки. Перед переходом на следующую строку 
высвечивается предложение 

Рге55 ЗРАСЕ іо Зіер, 3 іо ЗизрепсІ, ог Е$с іо СапсеІ... 

В качестве ответа можно нажать клавишу Пробел для 
следующего шага, букву 5 для приостановки программы и 
перехода в командный режим или клавишу Е$с для прекраще¬ 
ния выполнения программы. 

К средствам отладки можно также отнести команду ЗЕТ 
НЕІ.Р ОИ (устанавливается по умолчанию), которая высвечивает 
сообщение об ошибке в команде, выполняемой в командном 
режиме, и предлагает на выбор прекратить ее выполнение 
(САИСЕІ.), отредактировать команду (ЕОІТ) или получить по 
ней справочную информацию. Эту информацию о ^любой 
команде или функции можно также высветить командой НЕІ.Р 
[<ключевое слово>], в которой в качестве ключевого слова 
задается имя команды, функции или раздела справочной 
информации. Команда без ключевого слова высвечивает 
содержание справочной информации, что эквивалентно нажатию 
клавиши Р1. 

Тип монитора обычно устанавливается как параметр в файле 
СопІід.сІЬ. Однако для конкретной конфигурации можно задать 
тип монитора и число строк экрана командой 

ЗЕТ 0І5РІ.АѴ ТО М0Ы0/С0ЮК/Е0А25/Е0А43/М0К043 

В командном языке сіВАЗЕ IV имеется несколько команд и 
функций, играющих вспомогательную роль. В их число входит 
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команда $ЕТ НОІІЯ5 ТО [12/24], которая устанавливает время, 
высвечиваемое на экране ПК в 12- или 24-часовом формате. По 
умолчанию устанавливается 12-часовой формат. Опытным 
пользователям полезны функции 0$() и ѴЕЯ5ЮИ(), возвраща¬ 
ющие имя операционной системы и номер версии сІВАЗЕ IV, 
для учета специфики установленной операционной среды в 
разрабатываемых прикладных программах. 


3.7. ВЫЧИСЛЕНИЯ И ОБРАБОТКА СТРОК 

В предыдущих разделах описаны основные команды и 
функции по созданию файлов БД и манипуляции данными. С 
их помощью можно организовать любые вычисления. 

Однако в языке сІВАЗЕ IV имеется ряд команд и функций, 
специально предназначенных для выполнения стандартных 
вычислительных операций над данными. Например, для вычисле¬ 
ния среднего арифметического значения числовых полей файла 
БД можно использовать команду 

АѴЕЯА6Е [<список выр.Н>] [<диапазон >] 

[РОЯ<условие>] [\ѴНИЕ< условие>] 

[ТО < список переменных >/ 

ТО АЯЯАѴсимя массива >] 

Как это видно из синтаксиса команды, можно вычислять 
среднее арифметическое не только отдельных полей, но и 
любых разрешенных выражений с числовыми данными, в 
которые могут входить различные поля, переменные, функции, 
связанные операторами (см. определение выражения в разд. 
3.1). Напомним, что опции РОЯ и ѴЖНЕ определяют условия 
отбора записей из заданного диапазона. 

Результаты усреднения записываются в указанные в списке 
переменные или элементы одномерного массива в порядке, 
определяемом списком выражений. Если не указан список 
выражений, определяющих усредняемые данные, то по умолча¬ 
нию усредняются все числовые поля. 

Если установлено состояние $ЕТ ТАІ.К ОИ, то результаты 
выводятся на экран. Такой вывод можно использовать, если не 
требуется заносить результаты в переменные или массив. Если 
переменных или элементов массива больше, чем выражений в 
списке, то оставшиеся после записи переменные или элементы 
массива сохраняют свои значения. В противном случае оставшие¬ 
ся не записанными результаты усреднения игнорируются. 

Пример: 

У$Е $о*г 

* Вычисляется средняя зарплата сотрудников 1 отдела 

АѴЕКА6Е Іагрі РОК 0*сІ-"0 I м ТО Згесігаг 
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Для выполнения стандартных статистических расчетов можно 
использовать команду 

СЛЮШАТЕ [диапазон] <список опций > 

[РОК <условие>] [>ѴНИЕ< условие>] 

[ТО < список переменйых> / 

ТО АККАѴ <имя массива >] 

В состоянии $ЕТ ТАІ.К ОИ результаты выводятся на экран. 
Если при этом также установлено состояние ЗЕТ НЕАРІИО ОИ, 
то выводятся имена полей и функций. Опция ТО позволяет 
записать результаты вычисления функций в переменные или 
массив. 

Статистическая операция задается в списке опций в виде 
функций с аргументами, которые определяют поле файла БД: 

АѴ©( < выражение > ) - вычисляется среднее арифметичес¬ 

кое поля данных; 

сити - подсчитывается количество записей в файле БД, 
удовлетворяющих условию, заданному опцией РОК, т.е. когда 
условие оценивается как .Т.; 

МАХ( < выражение > ] - определяется наибольшее по 

величине значение числовых полей, полей типа даты и символь¬ 
ных полей; 

МІИ( < выражение > ) - определяется наименьшее значение 

аналогично предыдущей функции; 

ИРѴ( < процент>, < поступления >, < начальное значение > ) 
- вычисляется чистое текущее значение накопленной суммы 
денежных средств, где 

<процент> - процент, представленный десятичной дробью; 

< поступления > - серия денежных поступлений или 

платежей (числа со знаками + или -), записанных В поле 
данных, которое может быть представлено выражением; 

< начальное значение > - числовое выражение, представляю¬ 
щее начальное значение вложенных денежных средств, которое 
записывается со знаком "минус", так как является платежем; 

5ТО( < выражение > ) - вычисляется среднеквадратическое 

отклонение значений поля данных; 

ЗІІМ( < выражение >) - вычисляется сумма значений поля 

данных; 

ѴАК( < выражение >) - вычисляется дисперсия значений 

поля данных. 

Пример: 

113Е Ріпапз 

САКЖАТЕ РОЙ ’01' ЗУМ(Рау) г СЙТ() ТО Тоірау, Коі 

? "Количество сотрудников="+І_ШМ($ТК(Ко1 ,3)) + ; 

"Выплаченная сумма="+ИЙ1М($Тй(ТоТрау,8 | 2)) 

В число статистических функций предыдущей команды 
входит одна, связанная с финансовыми расчетами. Кроме того, 
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ряд стандартных финансовых расчетов можно выполнить с 
помощью специальных функций. Так, функция 

РУ (< депозит > г < процент > г < число периодов >) 

позволяет вычислить общую сумму равных регулярных депози¬ 
тов в течение заданного числа периодов времени при фиксиро¬ 
ванном проценте, где < депозит> - числовое выражение, 
значение которого может быть положительным или отрицатель¬ 
ным числом; <процент> - процентная ставка каждого периода, 
выражаемая положительной десятичной дробью; < число 
периодов> - числовое выражение, представляющее количество 
платежных периодов. 

Для вычисления постоянных регулярных платежей, требуе¬ 
мых для погашения кредита с постоянным процентом в течение 
заданного числа платежных периодов, используется функция 

РАѴМЕИТ( < кредит >, < процент >, < число периодов >) 

где <кредит> - числовое выражение, представляющее сумму 
кредита (может быть положительным или отрицательным 
числом); <процент> - процентная ставка каждого периода, 
выражаемая положительной десятичной дробью; < число 
периодов> - числовое выражение, представляющее количество 
платежных периодов. 

Для вычисления суммы вложенных денежных средств 
используется функция 

РѴ( < платежи >, < процент >, < число периодов >) 

где < платежи > - числовое выражение, представляющее 

постоянные регулярные платежи, которые могут быть положи¬ 
тельным или отрицательным числом; <процент> - процентная 
ставка каждого периода, выражаемая положительной десятичной 
дробью; < число периодов > - числовое выражение, представля¬ 
ющее количество платежных периодов. 

Кроме команды САІ.СШ.АТЕ количество записей файла БД 
в указанных границах, удовлетворяющих заданным условиям, 
можно подсчитать и записать в переменную командой 

СОІІИТ [ТО < переменная > [< границы >] 

[РОЛ < условие >] 

[\ѴНИЕ <условие>] 

Пример: 

У$Е Рокиркі 

СОМТ РОЛ ПКЕ(' 03/77/89 ', 0Т0С(0а1е_рокир)) ТО Маг*_ 2 ак 

? "Количество заказов в марте="; 

+І_ШМ($ТК(Маг1_2ак,3, 0)) 

Суммирование данных можно выполнить командой 

$11М [< границы >] [< список выражений >] 
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[ТО < список переменных > 

ДО АКШ <имя массива >] 

[^НИЕ <условие>] [РОК <условйе>] 

Размещение результатов и другие варианты использования 
данной команды аналогичны командам АѴЕКАСЕ и САІ.СШ-АТЕ. 
Результатом суммирования является число типа Р. 

Пример: 

1)$Е Ппапз 

0ЕС1.АКЕ Мзит [2] 

ЗЫМ Окіасі, Ооріаіа ТО АККАѴ Мзиш 

? "Сумма основного оклаАа="+5Тк(Мзит [1],3,0) 

? "Сумма доплат="+$ТК(Мзіті [2],3,0) 

Одной из типовых вычислительных операций является 
подсчет подытогов, выполняемый с помощью команды 

ТОТАІ. ОМ < ключевое поле> ТО <имя файла > 
[<границы>] [РІЕЮ5 <список полей>] 

[РОК < условие >] [ѴЖІЫЕ < условие >] 

которая вычисляет подытоги числовых .полей записей (всех 
полей или указанных в списке полей) с одинаковыми значения¬ 
ми заданного ключевого поля активного файла БД и записывает 
результаты в новый файл. По умолчанию расширение нового 
файла имеет вид ,6Ы. Активный файл БД должен быть 
проиндексирован или отсортирован по ключевому полю. Новый 
файл БД имеет ту же структуру, что и суммируемый файл 
(исключая поля Мето). Числовые поля нового файла содержат 
подытоги, а другие - значение - соответствующего поля первой 
записи из группы с одинаковым значением ключевого поля. 
Если размер поля в новом файле слишком мал для занесения 
результата суммирования, то в качестве значения поля помеща¬ 
ются знаки *, обозначающие переполнение. 

Кроме описанных команд и функций в языке СІВА5Е IV 
имеется достаточно большой набор математических функций, 
функций обработки символьных данных и данных типа даты, а 
также ряд вспомогательных функций, позволяющих выполнять 
широкий спектр действий по обработке данных. 

Рассмотрим сначала математические функции. К их числу 
относится вычисление квадратного корня $ОКТ( < выр.Ы >) и 
абсолютного значения АВ$(<выр.Н >) числового выражения, 
экспоненты ЕХР(<выр.Н >), десятичного К-ОС10(<выр.И>) и 
натурального ЮС( <выр.Н >) логарифмов. Функция РІ() 
возвращает число "пи". В группу тригонометрических функций 
входит синус 5ІИ( <выр.И >), косинус СО$(<выр.И>) и 
тангенс ТАН(<выр.Ы>) угла, заданного в радианах. Результат 
этих тригонометрических функций возвращается в виде числа 
типа Р. 
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Обратные тригонометрические функции представлены 
функциями арксинус А$ІЫ(<выр.Н >), арккосинус 

АСО§( <выр.И >), арктангенс АТАЫ(<выр.Ы>) и функцией 
АТЫ2( < выр.ЫІ >, < выр.Ы2 >), которая вычисляет функцию 
арктангенс для заданного значения синуса (выр.ЫІ) и косинуса 
(выр.Н2). Все обратные тригонометрические функции возвра¬ 
щают результат в радианах. Для перевода градусов в радианы 
используется функция ОТОК( <выр.Ы > ), а обратно (из радиан 
в градусы) - КТОО( <выр.И >). 

Функция СЕ11.1ИС( < выр.Ы > ) вычисляет наименьшее целое, 
которое больше или равно заданному числовому выражению, 
а РІ_ООК(< выр.Ы >) возвращает наибольшее целое число, 
которое меньше или равно заданному числовому выражению. 
Для округления чисел можно использовать функцию 
КОІІЫО( < выр.ИІ > г < выр.И2 >), в которой первое выражение 
задает округляемое число, а второе - количество оставляемых 
дробных десятичных позиций. При задании в последнем 
выражении отрицательного числа округляется соответствующее 
число позиций целой части числа. 

Функция ІЫТ(<выр.Ы>) преобразует числовое выражение 
в целое число посредством отбрасывания дробной части. Для 
возвращения большего или меньшего из двух чисел, дат или 
символьных выражений применяются соответственно функции 

МАХ(< выр.ЫІ >/<выр.01 >,<выр.Ы2>/<выр.02>) 

и 

МІЫ(<выр.ЫІ >/<выр.01 > , <выр.Ы2>/<выр.02>) 

Остаток от деления двух числовых выражений возвращается 
функцией МОР( < выр.ЫІ > г < выр.Ы2> ). Предусмотрена также 
функция КАЫО([ < выр.Ы > ]) для вычисления случайного числа 
в диапазоне от 0 до 0.999999, в которой числовое выражение 
определяет базу для вычисления следующего случайного числа. 
Если задано отрицательное число, то в качестве базы выбирает¬ 
ся системное время. В качестве базы по умолчанию принято 
число 100001. 3 нак числа можно определить функцией 

$ІСН(<выр.Ы >), которая возвращает 1, если числовое 
выражение положительное, -1 - если отрицательное и 0 - для 
нуля. 

Для обработки символьных данных в языке СІВА5Е IV 
предусмотрена довольна большая группа функций. Нередко при 
обработке строк требуется найти начальную позицию слова или 
его части в тексте. Для этого используется функция 
АТ(<выр.С> г <выр.С>/<имя Мето поля>), которая возвра¬ 
щает число, представляющее собой начальную позицию первой 
символьной строки во второй символьной строке или в поле 
Мето. Функция 1.ЕРТ(<выр.С>/<имя Мето поля> г <выр.Ы>) 
позволяет извлечь заданное число символов из символьного 
выражения или поля Мето, начиная с первого символа слева, 


270 



а функция КІСНТ(<выр.С>/<переменная>,<выр.Н>) - из 
символьного выражения или переменной, начиная с последнего 
символа справа. Для ввода в строку заданной подстроки и 
удаления части исходной строки можно использовать функцию 

5ТІІРР( < выр.СІ >, < выр.ИІ > г <выр.И2>, <выр.С2>) 

в которой первое символьное выражение задает исходную 
символьную строку или переменную, а первое числовое 
выражение определяет номер позиции этой строки, с которой 
вводится подстрока, задаваемая вторым символьным выражени¬ 
ем. Если эта позиция равна нулю, то ввод подстроки начинается 
перед первым символом. Если номер позиции выходит за 
пределы строки, то ввод начинается после последнего символа. 
Второе числовое выражение задает число удаляемых символов 
из исходной строки вправо, начиная с позиции ввода подстроки. 
Если это число равно нулю, то из исходной строки не удаляет¬ 
ся ни одного символа. 

Выше были описаны функции извлечения подстроки из 
символьной строки справа или слева. Похожими возможностями 
обладает функция 

$ІІВ$ТК(< выр.С >/< имя тето поля>, 

< начальная позиция >[,< число символов >]) 

позволяющая извлечь заданное число символов из символьного 
выражения или поля Мето. Если число символов не задано или 
же оно больше длины строки, то извлекается подстрока с 
начальной позиции и до конца строки. Часто при обработке 
строки требуется определить ее длину. Для этого можно 
использовать функцию І.ЕЫ(<выр.С>/<имя тето поля>), 
которая возвращает длину указанного выражения или содержи¬ 
мого поля Мето. Весьма полезными являются функции 
ИКІМ(<выр.С>) и &ТКІМ(<выр.С>) или ТКІМ( <выр.С> ), 
первая из которых удаляет ведущие (левые), а вторая и 
третья - конечные (правые) пробелы. При поиске данных 

нередко нужно определять, с какой буквы - строчной или 
прописной - начинается строка. Для этого применяются функции 
І$ЮУ^ЕК( < выр.С >) и ІЗІІРРЕѴЦ < выр.С >), возвращающие 

логическое значение .Т., если указанное символьное выражение 
начинается соответственно со строчной или прописной буквы. 

Преобразование строчных букв в прописные и наоборот 
можно выполнить функциями ІІРРЕВ( < выр.С >) и 

ЮѴ/ЕР(< выр.С >). Для создания строки с повторяющимися 
подстроками используется функция РЕРИСАТЕ(< выр.С >, 
<выр.Ы>), в которой подстрока указывается символьным, а 
число повторений - числовым выражением. Строку, состоящую 
из заданного числа пробелов, можно получить функцией 
$РАСЕ( < выр.И >). Если требуется сцепить символьные и 
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числовые данные, то последние нужно преобразовать к 
символьному типу. Это можно сделать функцией 

$ТК( < выр.И > [, < длина > ] [, < число десятичных позиций > ]) 

которая преобразует число в символьную строку. Здесь длина 
определяет полное число символов в создаваемой функцией 
строке, включая десятичную точку, знак "минус" и дробные 
десятичные позиции, число которых определяется отдельной 
опцией. 

Если длина и число дробных десятичных позиций не заданы, 
то по умолчанию предполагается 10 символов и число округля¬ 
ется до целого. Если длина строки меньше, чем число цифр в 
целой части числового выражения, то выводится знак *. Для 
обратного преобразования (из символьного типа в числовой) 
используется функция ѴАЦ <выр.С> ). Если в начале символь¬ 
ного выражения стоит не цифра или не пробел, то возвращает¬ 
ся 0. Символы цифр переводятся в числовое значение до тех 
пор, пока не встретится нецифровой символ. К числу функций 
обработки строк можно также отнести функции А$С(<выр.С>) 
и СНК( <выр.И> ). Функция А$С(<выр.С>) возвращает 
десятичный код А5СІІ первого символа заданного выражения, 
а функция СНК{<выр.Ы>) преобразует десятичный код А5СІІ, 
заданный числовым выражением, в символ и позволяет вывести 
на экран или принтер любой символ из расширенного набора 
ІВМ. Числовое выражение может включать числа от 1 до 255. 
Следует отметить, что не все принтеры поддерживают набор 
символов ІВМ. Поэтому перед выводом на принтер следует 
убедиться по его руководству, что предполагаемые для печати 
символы им поддерживаются. Код А5СІІ 7, заданный в качестве 
аргумента функции, инициирует звуковой сигнал. При включении 
функции с аргументом нуль СН&(0) в команду, она должна 
помещаться слева от оператора отношения, поскольку при 
выполнении оператора отношения сначала анализируется правая 
часть и при обнаружении нулевой строки операция прекращает¬ 
ся и возвращается логическое значение .Т. 

Примеры: 

. ? СНК(85) 

А 

. (Ж(7)+"Будьте внимательнее!” 

ррр = "Иванов” 

? ррр = СНК(О) 

Л. 

? СНК(О) * ррр 

.Г. 
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Ряд числовых функций возвращает результаты в форме с 
плавающей запятой (тип Р). Преобразование этой формы в 
двоично-десятичную форму числа (тип И) выполняется функ¬ 
цией РІХЕР( <выр.Н >). Нередко используется и обратное 
преобразование (из типа N в тип Р) функцией 
Р1-ОАТ(<выр.Н>), например для внутреннего представления 
результатов вычисления, когда получаются очень большие или 
очень малые числа. 

Довольно большая группа функций позволяет обрабатывать 
данные типа даты. В предыдущих разделах уже упоминалась 
функция СТОй( <выр.С> ) для преобразования даты, записанной 
в символьном виде, во внутреннее представление данных типа 
даты. Обратное преобразование выполняется функцией 
РТОС( < выр.О > ), а функция ОТО$( < выр.О > ) преобразует 
выражение типа даты в символьную строку формата 
ССУУММОй, где СС - век; УУ - год; ММ - месяц; 00 - день. 
Такое преобразование выполняется независимо от установки 
команд $ЕТ СЕИитѴ и 5ЕТ ОЛТЕ. Первая команда, например, 
позволяет вводить дату в символьную строку, последняя - 
составлять сложное индексное выражение с датой, охватываю¬ 
щей несколько веков. 

При выполнении операций с датами нередко требуется 
получить число, обозначающее порядковый номер дня недели 
и месяца. Это можно сделать с помощью следующих функций: 
00\Ѵ(< выр.О >), возвращающей номер дня недели 

(воскресенье = 1), О АѴ( < выр.О >), возвращающей день 
месяца из выражения типа даты, МОИТН(< выр.О), возвраща¬ 
ющей номер месяца в дате. Для возвращения названия дня 
недели и месяца используются функции СОО>У( < выр.О > ) и 
СМОМТН(< выр.О >) Полное значение года (с цифрами века) 
возвращается функцией ѴЕАВ( < выр.О > ). Как уже отмечалось, 
по умолчанию принят американский формат даты: месяц, 
число, год. Для преобразования даты в формат вида: число, 
месяц, год - применяется функция ОМУ( < выр.О > ), а обратное 
преобразование в американский формат выполняет функция 
МОУ( < выр.О >). Функция ТІМЕ() возвращает системное время 
в виде символьной строки в формате ЧЧ:ММ:СС, где ЧЧ - 
часы; ММ - минуты; СХ - секунды. 

3.8. РАБОТА В СРЕДЕ ЛВС 

Пакет СІВА5Е IV может быть установлен для работы в 
однопользовательском и многопользовательских режимах 
(в среде ЛВС). Все программы и файлы, созданные в одно¬ 
пользовательском режиме, можно впоследствии использовать и 
в многопользовательском режиме, предварительно установив 
его. 
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Многопользовательский режим позволяет совместно и 
зачастую практически одновременно использовать (разделять) 
программы и файлы БД без потери их целостности, обеспечивая 
при этом защиту информации. 

Однако внешне видимое как одновременное разделение 
программ и данных на самом деле реализуется последовательно 
аппаратными и программными средствами ЛВС. 

Кроме этих средств в организации процесса разделения 
файлов обычно участвуют и средства используемых пакетов 
СУБД. В частности, пакет сІВАЗЕ IV обеспечивает четыре уровня 
защиты от одновременного доступа к файлам в среде ЛВС: 
захват файлов, захват записей, установку файла в исключитель¬ 
ное владение одним пользователем и процедуру обновления 
(транзакции) файла БД. 

Целостность файлов БД в среде ЛВС поддерживается 
специальными командами и функциями. Для ряда команд 
позволяющих, например, выполнять с клавиатуры ввод и 
обновление данных, захват файлов и записей осуществляется 
автоматически, а для других команд режим захвата можно 
установить специальной командой. При попытке открыть файл, 
захваченный или установленный для исключительной обработки 
каким-либо пользователем, в состоянии автоматического 
повторения попыток захвата появляется сообщение об ошибке: 
Рііе і$ іп и$е Ьу <имя>. Кеігуіпд Іоск, рге$$ Е$с іо сапсеі. 
(Файл захвачен пользователем <имя>. Попытки захвата 
повторяются, для отмены нажмите клавишу Е$с.) 

При отсутствии состояния автоматического захвата высвечива¬ 
ется сообщение: Рііе і$ іп и$е апоіЬег. Кеігуіпд! (файл захвачен 
другим пользователем. Попытайтесь еще !) В этом случае 
имеется возможность повторить попытку, выбрав позицию ВЕТКУ 
меню на экране. Если и после этого файл не открывается, то 
снова высвечивается то же сообщение. Выбор позиции АВОКТ 
прекращает попытки открыть файл. 

Если пользователь входит в запись разделенного файла БД 
с целью обновления, то сначала осуществляется попытка 
захватить эту запись и другие связанные с ней записи. Если эти 
записи уже захвачены другим пользователем, то в состоянии 
автоматического повторения захвата появляется сообщение об 
ошибке: КесогсІ і$ іп и$е Ьу <имя>. Кеігуіпд Іоск, рге$$ Е$с іо 
сапсеі. (Запись захвачена пользователем <имя>. Попытки 
захвата повторяются, для отмены нажмите клавишу Е5С) Если 
захват оказывается успешным, система определяет, были ли 
выполнены изменения другим пользователем в каком-либо поле 
после того, как осуществлен доступ к записи. Если изменения 
были, то они высвечиваются на экране. 

При отсутствии состояния автоматического повторения 
захвата в случае захвата записи другим пользователем появляет¬ 
ся другое сообщение: КесогсІ і$ іп и$е апоІЬег. Кеігуіпд! 
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(Запись захвачена другим пользователем. Попытайтесь еще !) 
В этом случае, как и при захвате файла, имеется возможность 
повторить попытку, выбрав позицию РЕТРѴ. Если и после этого 
захват записи не выполняется, то снова высвечивается то же 
сообщение. Выбор позиции АБОРТ прекращает запрос на 
обновление записи. 

Для установки режима автоматического захвата записей и 
файлов БД при выполнении любых команд используется 
команда ЗЕТ І.ОСК ОН (задается по умолчанию). Захваченный 
пользователем файл или запись другой пользователь может 
только читать. После завершения выполнения команды захват 
файла или записи также автоматически освобождается. 

При установке состояния $ЕТ ЮСК ОРР автоматический 
захват отменяется не для всех команд а только для команд, 
выполняющих действия в режиме чтения. Для команд, которые 
имеют как режим чтения, так и записи данных автоматический 
захват отменяется только для режима чтения. Ниже в табл. 3.9 
приводится список команд, которые автоматически захватывают 
файлы. 


Таблица 3.9. Перечень команд, автоматически захватывающих 

файлы 


Команда 

захвата 

Выполняемое 

действие 

Уровень 

Отмена 

командой 

ЗЕТ ЮСК ОРР 

06ЕТ/ЙЕАО 

Редактирование 

Запись 

Нет 

АРРБИЭ ГРОМ 

Обновление 

Файл 

Нет 

АРРЕМ [ВІ-АИК] 

Обновление 

Запись 

Нет 

АѴЕКА6Е 

Только чтение 

Файл 

Да 

ВК0Ѵ5Е 

Редактирование 

Запись 

Нет 

САЮІЛАТЕ 

Только чтение 

Файл 

Да 

СНАМѲЕ/ЕОІТ 

Редактирование 

Запись 

Нет 

СОРУ ТА6/ШЕХ 

Чтение/Запись 

Файл 

Да (чтение),Нет (запись) 

сорѵ[$пи)стіліЕ] 

Чтение/Запись 

Файл 

Да (чтение),Нет (запись) 

ссшт 

Только чтение 

Файл 

Да 

ОЕЬЕТЕ/КЕСАИ 

Обновление 

Запись 

Нет 

ОЕЬЕТЕ/КЕСАИ 

Обновление 

Файл 

Нет 

ЕОІТ 

Обновление 

Запись 

Нет 

ІНОЕХ 

Чтение/Запись 

Файл 

Да (чтение),Нет (запись) 

іЗОІИ 

Чтение/Запись 

Файл 

Да (чтение),Нет (запись) 

І_АВЕІ_ 

Только чтение 

Файл 

Да 

КЕРБАСЕ 

Обновление 

Запись 

Нет 

РЕРБАСЕ [диапазон] 

Обновление 

Файл 

Нет 

РЕРОРТ 

Только чтение 

Файл 

Да 

$ЕТ САТАЮб ои 

Каталог 

Файл 

Нет 

50РТ 

Чтение/Запись 

Файл 

Да (чтение),Нет (запись) 

зим 

Только чтение 

Файл 

Да 

ТОТАЬ 

Чтение/Запись 

Файл 

Да (чтение),Нет (запись) 

иРОАТЕ 

Обновление 

Файл 

Нет 
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Команды ВКО№Е, ЕЭІТ и СНАНОЕ обеспечивают автомати¬ 
ческий захват только одной, обновляемой в текущий момент 
записи, тогда как остальные записи доступны для обновления 
другим пользователям. Захват осуществляется собственно в 
момент выполнения изменений. После завершения изменений и 
перехода к следующей записи или файлу захват записи или 
файла автоматически освобождается и запись или файл могут 
обновляться другим пользователем. Захваченный файл всегда 
может просматриваться другим пользователем. Таким образом, 
в этих командах реализован весьма гибкий метод защиты от 
одновременного обновления, что позволяет другим пользовате¬ 
лям в ЛВС просматривать и редактировать не захваченные 
записи. 

Захват записи в командах осуществляется автоматически при 
редактировании каждого поля в момент, когда нажимается 
любая, кроме навигационных, клавиша. Для явного указания 
захвата записи можно использовать клавиши ОгІ-О, а для 
освобождения от захвата - повторно клавиши СІгІ-О или ОН-Р. 
При передвижении курсора на другую запись захват записи, на 
которой был курсор, автоматически освобождается за исключе¬ 
нием команды КЕРІ.АСЕ. При выполнении этой команды в 
случае, когда в качестве диапазона обновляемых записей 
установлена не одна запись, захват не освобождается до тех 
пор, пока не будет выполнена другая команда. Если следующей 
опять выполняется команда КЕРІ.АСЕ, то запись остается 
захваченной. Это обеспечивает обновление всех данных одной 
записи до освобождения ее захвата. В дополнение к автомати¬ 
ческому захвату можно захватывать файл БД в текущей или 
указанной алиасом рабочей области с помощью функции 
РЮСК([алиас]). В этом случае, как и при автоматическом 
захвате, другой пользователь может только читать, а не 
обновлять файл. Обычно такой захват применяется перед 
выполнением операций с файлом БД как с целым. После 
успешного захвата эта функция возвращает логическое значение 
.Т., а при попытке захвата уже захваченого файла возвращается 
логическое значение .Р. Если захваченный файл связан с 
другими файлами, то все связанные файлы также захватываются. 
При освобождении от захвата одного из связанных файлов 
автоматически освобождаются и другие. 

В том случае, когда пользователю нет необходимости 
захватывать весь файл, можно использовать функцию 
КЮСК([ < список выр.С > г < ал нас > ]/[ < алиас > ]) для захвата 
одной или нескольких записей. Вместо слова КЮСК можно 
использовать альтернативный глагол ЮСК. В списке символь¬ 
ных выражений задаются номера захватываемых записей 
(например, 1,2,5,7,9). Если список не указан, то захватывается 
текущая запись в файле БД. Задание алиаса позволяет захваты¬ 
вать записи файла БД из другой (не активной в текущий 
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момент) рабочей области. Напомним, что алиасом может быть 
номер рабочей области, имя файла БД или косвенная ссылка 
на файл БД (имя переменной, которая содержит имя файла 
БД). Если файл БД, в котором захватываются записи, связан с 
другими (командой $ЕТ &ЕІ.АТІОН), то захватываются и все 
связанные записи, но в количестве не более 50. Для проверки 
захвата используется эта же функция без аргументов, которая 
в случае успеха захвата всех записей возвращает логическое 
значение .Т. Если хотя бы одна запись из . списка не может 
быть захвачена, то не происходит захвата и других записей и 
функция кюскп возвращает логическое значение .Р. Другие 
пользователи могут только читать захваченные функцией 
кюскп записи. Освобождение захваченных функциями 
РЮСК() и КЮСКП записей осуществляется только командой 
ІЖЮСК, после закрытия файла БД или выхода из СІВА5Е IV. 

Для того чтобы обнаружить захват записи другим пользова¬ 
телем, нужно, чтобы при захвате была записана соответствющая 
информация Естественно эту информацию помещать в эту же 
запись. Но для хранения такой информации нужно выделить 
специальное поле. В СІВА5Е IV добавление этого поля в 
структуру файла БД выполняется командой СОИУЕКТ [ТО 
<выр.Ы>], которая вводит поле с именем _сІЬа$еІоск в 
структуру БД и создает новый файл БД с тем же именем и 
расширением. При этом старый файл остается и ему присваива¬ 
ется расширение .сѵі Поле _сІЬа5еІоск содержит информацию, 
необходимую для обнаружения захвата полей в многопользова¬ 
тельском режиме. Длина этого поля определяется заданным 
выражением и может быть от 8 до 24 байт (по умолчанию - 
16). Это поле резервируется для хранения следующих значений: 

счетчика обновлений (Соипі), представляющего двухбай¬ 
товое шестнадцатеричное число, используемое функцией 
СНАИСЕП для обнаружения факта обновления записи; 

времени захвата (Тіте), представляющее трехбайтовое 
шестнадцатеричное число; 

даты захвата (Оаіе), представляющей трехбайтовое 
шестнадцатеричное число; 

имя пользователя (компьютера) (Иате), осуществившего 
захват (длиной до 16 символов). 

Счетчик, время и дата размещаются в первых восьми 
позициях поля _сІЬа$еІоск. Остальную часть поля в зависи¬ 
мости от установленной длины занимает имя пользователя 
(компьютера), осуществившего захват. Если поле занимает 8 
байт, то имя пользователя не вводится. При каждом обновлении 
записи изменяется значение счетчика поля _4Ьа$еІоск. функция 
СНАИСЕП считывает это значение из поля, записанного на 
диске, и сравнивает со значением счетчика, записанным в 
системной переменной с этим же именем при считывании 
записи в память. 
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Различия этих значений означает, что запись обновлялась 
другим пользователем, и функция СНАИСЕП возвращает 
логическое значение .Т. При перемещении указателя на другую 
запись возвращается логическое значение .Р. Команда СОТО 
КЕСИОО читает заново поле ..сІЬазеІоск текущей записи и 
последующее выполнение функции СНАИСЕП уже возвращает 
логическое значение .Р. до тех пор, пока другой пользователь 
не обновил запись. Следует отметить, что использование 
функции СНАИСЕП не всегда правильно фиксирует изменения 
в записи, хотя счетчик обновлений правильно отражает обновле¬ 
ние записи в ходе транзакции. В случае прекращения транзак¬ 
ции и восстановления исходного файла командой КОШЗАСК этот 
факт не будет отражен в поле _сІЬа5еІоск и соответственно 
функция СНАИСЕ() будет неправильно отражать ситуацию. 
Информацию из поля _сІЬа$еІоск можно извлечь функцией 
І.К$Ѵ$(п), которая при п = 0 возвращает время, при п = 1 дату 
захвата, а при п=2 имя пользователя (компьютера), захватив¬ 
шего запись или файл. 

Как уже отмечалось, записи, захваченные функцией 
КЮСК(), нужно освобождать командой ШЧІ.ОСК [АИ/ІЫ 
<алиас>], если только вообще файл БД не закрывается или 
не выполняется выход из сІВАЗЕ IV. Эта команда освобождает 
от захвата любым пользователем запись или файл в текущей 
рабочей области или заданной алиасом, что позволяет другим 
пользователям модифицировать данные. Если последним 
захватом был захват записи, то освобождаются все записи. Если 
же последний захват был захватом файла, то этот файл и 
освобождается. 

Опция АІ-І. позволяет освободить все сделанные захваты 
записей и файлов во всех рабочих областях, а опция ІЫ 
освобождает записи и файлы от захвата в указанной рабочей 
области. 

Пример: 

іізе по 

ІР К1_0СК() = .Т. 

КЕРІ.АСЕ Рат УІТН "Петров” 

ЛЕРЕАСЕ Иате УІТН "Петр" 

ІЖОСК 

Е N ОIР 

Известно, что факт захвата файла или записей другими 
пользователями можно установить функциями РЮСКО И 
КЮСК(). с целью обнаружения освобождения захвата надо 
периодически повторять попытки захвата. Для автоматизации 
этого процесса можно использовать команду $ЕТ КЕРКОСЕ55 ТО 
<выр.Н>, которая устанавливает число (от -1 до 32000, по 
умолчанию 0), определяющее количество попыток захвата записи 
или файла в ЛВС перед выводом сообщения об ошибке. 
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Неограниченное число попыток устанавливается числом -1. Если 
установлено значение 0 и не установлено состояние ОЫ ЕККО&, 
то при попытке захвата записи или файла другим пользователем 
выводится сообщение: РІеазе \^аіі, апоЖег и$ег Ьаз Іоскесі іНі$ 
гесогсі ог (Не (Пожалуйста, подождите, другой пользователь 
захватил запись или файл) и процесс захвата повторяется 
неограниченно. Для выхода из этого процесса можно использо¬ 
вать клавишу Е$с. При установке числа больше 0 приведенное 
выше сообщение не высвечивается. 

Команды ВКОѴ5Е и ЕРИ, как уже отмечалось, позволяют 
одновременно обновлять один файл БД несколькими пользовате¬ 
лями. В* этом случае важно отслеживать процесс обновления и 
знать, какие именно записи уже были обновлены. Это можно 
сделать с помощью команды 5ЕТ КЕРКЕ5Н ТО <выр.И>, 
которая устанавливает интервал времени между проверками 
файла с целью определения выполненных изменений в файле 
в среде ЛВС командами ВКО>^$Е и ЕОІТ. При этом файл БД 
должен быть предварительно реорганизован командой СОИѴЕ&Т 
с целью введения поля _сіЬа$еІоск. Численное выражение 
задает интервал времени в секундах в диапазоне от 1 до 3600 
секунд (по умолчанию 0). По истечении заданного интервала 
на экран выводятся все обновленные данные. Если интервал 
равен 0, то проверка файлов не выполняется. 

Выше была рассмотрена защита целостности данных в среде 
ЛВС на уровне захвата файлов и записей, которая дает 
возможность одному пользователю обновлять, а другим только 
просматривать разделенные файлы. 

Следующий уровень защиты - это установка файла в 
исключительное распоряжение одним пользователем, так что 
другие пользователи не имеют никакого доступа к этому файлу, 
т.е. даже не могут его читать. Такая установка выполняется 
командой 5ЕТ ЕХСШ5ІѴЕ ОЫ (ОРР по умолчанию). Команды 
СКЕАТЕ и 5АѴЕ автоматически устанавливают состояние $ЕТ 
ЕХСШ5ІѴЕ ОН. 

Кроме описанных в системе обеспечения целостности 
данных существует специальная команда для организации 
массового обновления данных (транзакции) как в однопользова¬ 
тельском режиме, так и в среде ЛВС: 

ВЕСІН ТКАЫЗАСТЮЫ [<маршрут по директориям>] 

< команды транзакции > 

ЕЫй ТКАЫ5АСТЮН 

Эта двухфазная команда позволяет начать транзакцию, 
записать сделанные в файле БД изменения и установить опцию 
для восстановления исходных значений (КОИВАСК). Вторая 
фаза командѣ завершает процесс обновлений файла БД и 
отменяет опцию коиваск. 
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Процесс обновления записей состоит из совокупности 
элементарных действий, включающих: 
добавление новых записей; 
изменение данных в записи; 

пометку записи для ее последующего удаления. 

Первая фаза команды ВЕСІИ ТВАЫ5АСТІОИ начинает 
записывать эти элементарные действия в создаваемый файл 
транзакции с именем ТгапзІод.Іод в однопользовательской среде 
и с именем <имя ПК>.1од в среде ЛВС, где <имя ПК> - 
имя компьютера, с которого стартует команда в ЛВС. В 
оглавлении файла БД помещается метка, указывающая на то, 
что файл находится в состоянии изменения. Если требуется 
отменить изменения и восстановить файл в исходное состояние, 
то для этого используется созданный файл транзакции. До 
выполнения команды ЕЫО ТВА5АСТІОМ файл транзакции 
находится в активном состоянии и позволяет удалить обновления 
и возвратить файл в исходное состояние с помощью команды 
ѴЮІ-І-ВАСК. Убедившись, что изменения выполнены правильно, 
можно перейти к выполнению фазы ЕЫО ТВАН5АСТЮИ. Эта 
команда деактивизирует транзакцию, удаляет файл транзакции 
и уничтожает метку состояния обновления файла. После этого 
для восстановления файла в исходное состояние можно 
использовать только страховые копии исходного файла. Перед 
началом новой серии обновлений необходимо завершить 
предыдущую серию. Следует отметить, что из команд транзак¬ 
ции нельзя создавать вложенные структуры и обе фазы 
команды должны находиться в одной процедуре. 

Команды, которые используются для обновления файлов или 
изменения параметров среды, также записываются в файл 
транзакции. В составе этих команд могут быть не только 
команды выполнения элементарных действия по обновлению, но 
также команды создания новых файлов БД и каталогов, 
индексных файлов и т.д. При этом могут применяться любые 
команды, которые не перезаписывают существующие файлы или 
не закрывают открытые файлы. Это ограничение требуется по 
той причине, что в противном случае нельзя будет выполнить 
команду КОиВАСК. 

Элементарные действия по обновлению обычно осуществля¬ 
ются следующими командами: АРРЕИР, ВВО>Ѵ$Е, СНАИСЕ, 
РЕІ.ЕТЕ, ЕйІТ, ВЕСАИ, ВЕР1.АСЕ, ЦРРАТЕ. 

Новые файлы могут создаваться соответствующими команда¬ 
ми, при условии, если они не закрывают открытых файлов: 

СОРУ [5ТВ1РСШВЕ] ТО <имя файла > [ЕХТЕЫОЕО] 

СВЕАТЕ <имя файла > [РВОМ симя файла >] 

ЕХРОВТ ТО <имя файла > 

ІМРОВТ РВОМ <имя файла> 

ІЫОЕХ...ТО <имя файла> 
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ЮІМ...ТО <имя файла> 

$ЕТ САТАЮО ТО <имя файла > 

50КТ...Т0 <имя файла > 

ТОТАІ....ТО <имя файла > 

Некоторые из этих команд разрешены при создании новых 
файлов и не разрешены, если они в ходе транзакции закрыва¬ 
ют открытые файлы: СКЕАТЕ [РВОМ], ІМРОКТ, ІЫОЕХ ОН, 5ЕТ 
САТАЮО ТО, $ЕТ ІНйЕХ ТО, Ц$Е. 

В ходе транзакции не разрешены следующие команды: 
СЬЕАК АН, СЮ$Е АП/й АТ А В А$Е/І ИОЕХ, 0Е1.ЕТЕ РНЕ, ЕКА5Е, 
Ш5ЕКТ, МООІРѴ 5ТІШСТШІЕ, РАСК, КЕНАМЕ, 2АР. 

При попытке выполнения этих команд в ходе обновления 
дается сообщение об ошибке. Вообще для полной гарантии 
восстановления исходного файла, перед проведением транзакции 
рекомендуется делать страховую копию. 

Пример: 

РР0СЕ01ЖЕ Ыакіасіп 
$ЕТ РЕРР0СЕ55 ТО 15 
ОИ ЕРРОР РО Егг_ргос 
ВЕ6ІН ТРАН5АСТІ0И 

113Е Иасіасіп ОРОЕР ЗсИеѣ 
ЗСАИ РОР .ИОТ. Есть 


ЕМЗСАИ 

ЕИО ТРАН5АСТIОН 

ір .йот. роиваско 

0 20,1 ЗАУ "Восстановление файла с помощью ; 

команды РОИВАСК не удалось " 

0 21,1 ЗАУ "Необходимо восстановить файл с ; 
помощью страховой копии" 

ЕШР 
0И ЕРРОР 
РЕТІЖИ 

РРОСЕОЫРЕ Егг_ргос 
оіѵеі: = " " 

00 САЗЕ 

САЗЕ ЕРР0РО + 108 && Файл захвачен другим пользователем 
0 20,10 ЗАУ " Файл захвачен другим пользователем" 

0 21,10 ЗАУ " Попытаться еще раз ? (Да/Нет)" ; 

СЕТ о*ѵе* 

РЕА0 

0 20,10 СІЕАР ТО 21,79 
ІР І^РЕР (оѣѵеЪ) = "ДА" 

РЕТРУ 

РЕТІЖР 

Е1.5Е 
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ІР СОМРЬЕТЕО () 

* - Ошибок в ходе обновления не было 

0 20, ІС ЗАУ "Файл, захваченный другим пользователем, ; 

не входит в состав транзакции" 

0 21,10 $АѴ "Возврат в главное меню" 

КЕТІШ ТО МАЗТЕК 
ЕНОІР 

0 20,10 ЗАУ "Файл восстанавливается в ; 

исходное состояние. Хдите ..." 

КОИВАСК 

ЕИОІР 

КЕШН ТО МА5ТЕР 
САЗЕ ЕКК0К() - 109 

. . . && Аналогичная процедура 

ЕЫ0САЗЕ 

КЕШИ 

Для проверки успешности завершения транзакции использу¬ 
ется функция СОМРІ.ЕТЕО(), которая возвращает логическое 
значение .Т., если транзакция файлов завершена успешно 
(была выполнена фаза ЕИР ТКАИ5АСТЮМ), и значение .Р., 
если выполнена только первая фаза ВЕСІЫ ТВАМ5АСТІОИ. 

В случае прекращения транзакции для восстановления 
исходных файлов применяется команда КОИВАСК [<имя файла 
БД>]. Кроме файлов БД эта команда восстанавливает индекс¬ 
ные файлы в состояние до их обновления, а также закрывает 
и удаляет все индексные файлы и файлы БД, которые создают¬ 
ся в ходе транзакции. Эта команда помещается между команда¬ 
ми начала ВЕСІЫ ТКАИХАСТЮИ и завершения транзакции ЕЫР 
ТКАН5АСТІОИ. Восстанавливаемые файлы должны быть открыты, 
а процесс транзакции должен быть завершен. Если не указыва¬ 
ется имя файла БД, то восстанавливаются все обновленные 
файлы БД, а при указании имени - только этот файл БД. 

Файл транзакции включает содержимое каждой записи до 
и после ее обновления. Команда КОИ.ВАСК сравнивает файл 
транзакции с содержимым активного файла БД, восстанавливает 
все выполненные изменения и приводит файл БД в исходное 
состояние. Неуспешное выполнение команды КОИВАСК может 
быть по двум причинам: 

нет соответствия между содержимым записей до и после 
обновления; 

файл транзакции не считывается. 

После успешного выполнения команды КОИВАСК файл 
транзакции восстанавливается в исходное состояние и остается 
открытым для обеспечения последующих транзакций. 

Пример: 

СМ ЕМОК КОИВАСК 

ВЕ6IN ТКАНЗАСТІ0Н 


282 



КЕР1.АСЕ АН Окіасі «ІТН 0к1асІ*1.1 

ЕМ ТКАМАСТШ 

Проверку успешности выполнения команды КОЫ.ВАСК 
можно осуществить с помощью функции КО^І-ВАСК(), которая 
возвращает логическое значение .Т., если последняя команда 
КОИВАСК выполнена успешно. В противном случае возвраща¬ 
ется .Р., до тех пор, пока или команда КОІ.І.ВАСК не будет 
выполнена успешно или не будет осуществлен выход из 
СІВА5Е IV. 

Как отмечалось выше, команда КОІ.І.ВАСК может не 
завершиться успешно или может возникнуть необходимость 
прекратить транзакцию, не прибегая к этой команде. В этом 
случае в оглавлении файла остается метка, указывающая на то, 
что файл все еще находится в состоянии обновления и, 
следовательно, недоступен для обработки. Для удаления этой 
метки используется команда ВЕЗЕТ [ІИ <алиас>], после 
выполнения которой файл БД становится доступным для 
последующего обновления. Эту команду можно использовать 
только в командном режиме для выхода из необычных 
ситуаций. Опция ІИ позволяет удалять метку состояния обновле¬ 
ния файла БД, находящегося в рабочей области, заданной 
алиасом. 

Для проверки того, находится ли файл БД в состоянии 
обновления, используется функция 1$МАККЕ0([ < алиао ]), 
которая возвращает логическое значение .Т., если в оглавлении 
файла БД есть метка о состоянии обновления, и .Р.^ если нет. 

К числу средств обеспечения целостности данных можно 
также отнести команду создания и поддержки защиты информа¬ 
ции РВОТЕСТ. Эта команда, управляемая с помощью меню, 
используется администратором банка данных для обеспечения 
защиты информации. Команда может применяться в однопользо¬ 
вательском и многопользовательском режимах и позволяет 
осуществить защиту информации на трех уровнях: 

защиту входа в систему; 

защиту файлов и полей данных; 

шифрование данных. 

Более подробно о системе защиты информации в СІВА5Е IV 
см. разд. 2.9. Здесь лишь упомянем, что важным элементом 
системы защиты информации является установка уровней 
доступа пользователей, которая выполняется администратором 
системы. Уровни доступа определяют привилегии по использова¬ 
нию данных в файлах БД. Численные значения уровней доступа 
пользователей применяются в системе защиты информации для 
определения возможности доступа к тем или иным данным в 
режиме, управляемом меню, и в программах обработки данных. 
Численное значение уровня доступа последнего вошедшего в 
систему пользователя можно определить с помощью функции 
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АССЕ$$(). Хотя эти значения хранятся в зашифрованном файле 
и поэтому недоступны другим пользователям, тем не менее их 
можно достаточно легко извлечь из некомпилированных 
программ с расширением .ргд, в которых используется функция 
АССЕ$$(). Поэтому при работе в среде ЛВС рекомендуется 
использовать только компилированные модули, а исходные с 
расширением .ргд удалять. Кроме того, целесообразно хранить 
файл данных о защите системы ОЬ$у$Іет.сіЬ в том же директо¬ 
рии, что и системные файлы СІВА5Е IV, во избежание его 
утраты. Если этого файла нет, то экран входа в систему не 
высвечивается. Для пользователя, вошедшего в систему минуя, 
экран входа, функция АССЕ$$() возвращает нуль, что не дает 
ему доступа к зашифрованным файлам. Поэтому в начале 
программы обработки файлов БД в среде ЛВС рекомендуется 
проверить уровень доступа каждого вошедшего в систему 
пользователя и если он равен нулю, то рекомендовать войти 
повторно или обратиться к администратору системы. 

Система защиты информации предусматривает автоматичес¬ 
кое шифрование файлов БД при их создании, если установлена 
команда 5ЕТ ЕМСКѴРТЮИ ОИ, которая обеспечивает шифрова¬ 
ние всех вновь создаваемых файлов БД (следует отметить, что 
при этом сохраняются и незашифрованные копии, которые надо 
удалить. Эта процедура описана в разд. 2.9). Однако в ряде 
случаев, при установленной системе защиты требуется создавать 
незашифрованные файлы БД или же расшифровывать уже 
созданные, например, с целью экспорта этих файлов. Установка 
состояния $ЕТ ЕНСКУРТІОИ ОРР (задается по умолчанию) 
позволяет создавать новые незашифрованные файлы при 
выполнении операций над ранее зашифрованными файлами, 
например, такими командами, как СОРУ, ДОІИ, ТОТАІ. и др. 

При работе в среде ЛВС обязательно подключается система 
защиты информации, хотя могут быть задействованы не все ее 
уровни. Однако уровень защиты входа в систему действует 
всегда. Чтобы войти в систему, пользователь набирает с 
клавиатуры свое системное имя, имя группы, в которой он 
будет работать, и пароль, которые были предварительно 
назначены администратором системы. После окончания работы 
в системе пользователь должен выполнить команду І.ОСОІІТ , 
которая фиксирует выход пользователя из системы и высвечива¬ 
ет экран - приглашение для нового входа в систему. Одновре¬ 
менно эта команда закрывает все открытые пользователем 
файлы БД и связанные с ними файлы, а также программные 
файлы. 

Для идентификации последнего пользователя, вошедшего в 
систему, используется функция ІІ$ЕК(), которая возвращает его 
имя. Полный состав пользователей ЛВС можно установить 
командой 0І5РІ.АѴ ІІ$ЕК$, которая выводит имена всех пользо¬ 
вателей (компьютеров), работающих в текущий момент в ЛВС, 
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считывая их из файла [.одіп.сІЬ, размещенного в текущем 
директории. Следует отметить, что имена компьютеров должны 
быть уникальными, так как если в ЛВС работают пользователи 
с одинаковым именем,-данная команда выводит это имя один 
раз. Функция ИЕТ>ѴОКК() позволяет определить, работает ли 
система сІВАЗЕ IV в среде ЛВС, и возвращает .Т., если да, и 
.Р., если нет. Эта функция может использоваться в программах 
для ветвления процесса выполнения операций в зависимости от 
того, установлен ли пакет сІВАЗЕ IV в среде ЛВС или нет. 


Глава 4 

ЯЗЫК 501 

4.1. ОБЩИЕ СВЕДЕНИЯ О ЯЗЫКЕ 5СИ 

Язык 501. был впервые разработан фирмой ІВМ и затем 
одобрен многими компаниями в качестве стандарта языка 
управления реляционными БД для больших и мини-ЭВМ. В то 
же время стандартом языка микро-ЭВМ фактически стал язык 
сІВАЗЕ. Использование языка 50І_ в СУБД сІВАЗЕ IV позволяет 
связать на логическом уровне программные среды больших и 
мини-ЭВМ с микро-ЭВМ. 

Этот язык ориентирован на операции с данными, представ¬ 
ленными в виде логически взаимосвязанной совокупности таблиц, 
в отличие от языка сІВАЗЕ, который ориентирован на операции 
с данными, представленными в виде записей. 

Использование концепции операций, ориентированных на 
табличное представление данных, позволило создать компактный 
язык 5СН- с небольшим набором команд. Это дало возможность 
достаточно легко определять, выводить и обновлять информа¬ 
цию в БД, упростив программирование сложных запросов. 
Таблица в языке 501 представляет собой совокупность строк и 
столбцов. В языке сІВАЗЕ строкам таблицы соответствуют записи, 
а колонкам - поля файла БД. 

Кроме обычных таблиц, язык 501. позволяет создавать 
особый тип таблиц - выборку, представляющую собой подмно¬ 
жество строк и колонок из одной или нескольких таблиц. Часто 
выборку называют виртуальной таблицей, поскольку она 
фактически не содержит данных, а только позволяет их 
выводить. Данные в выборке отражают их реальное изменение 
в соответствующих таблицах и, наоборот, изменение данных в 
обновляемых выборках приводит к изменению этих данных в 
соответствующих таблицах. Таким образом, языковые средства 
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ЗСН. в отличие от языка сІВАЗЕ IV обеспечивают автоматическое 
обновление связанных файлов БД. 

Особенность команд языка 501. состоит в том, что они 
ориентированы в большей степени на конечный результат 
обработки данных, чем на процедуру этой обработки. Система 
определяет оптимальный путь для вывода данных. Такой подход 
принципиально отличается от других языков управления 
данными, требующих знание структуры БД и последовательности 
операций, ведущих к выводу данных. 

Полный набор языка 501. включает менее 30 команд, 
обеспечивающих все операции, необходимые для определения 
таблиц, выборок, создания запросов на вывод, обновление, 
удаление и ввод информации. Команды языка 501. легко 
использовать, так как в них осуществляется ссылка на одни и 
те же элементы - строки и колонки таблицы или выборки. 

Для создания прикладных программ в операционных средах 
больших и мини-ЭВМ язык ЗСН- обычно используется вместе с 
языками программирования высокого уровня типа РОКТКАЫ, 
СОВОЬ, С. В программах сІВАЗЕ IV также можно комбиниро¬ 
вать язык 501- и сІВАЗЕ IV. 

Команды языка сІВАЗЕ IV позволяют создавать экранные 
формы ввода и вывода информации, разрабатывать и выводить 
отчеты, создавать меню и другие элементы прикладных 
программ, которые нельзя создать средствами языка 5СИ-. 

Языковые средства сІВАЗЕ IV также предназначены для 
общего управления выполнения прикладной программой. Язык 
501- ориентирован в основном на поиск и отбор данных, а 
также поддержание актуальности БД. 

Как и в языке сІВАЗЕ IV, команды ЗСН. могут выполняться 
в режиме набора с клавиатуры (командном режиме) и в 
программах. В командном режиме команды языка 50І_, так же 
как и команды языка сІВАЗЕ IV, выполняются по одной и 
результаты выводятся сразу после их выполнения. Выполнение 
команд сІВАЗЕ и ЗСН. осуществляется раздельно. Для этого 
предусмотрены два режима: на языке сІВАЗЕ (по умолчанию) 
и на языке 5СН-. При работе на языке 5СН_ допускается 
выполнение тех команд и функций сІВАЗЕ, которые не дублиру¬ 
ют соответствующие команды языка 501- или не имеют 
одинакового наименования. 

В прикладных программах команды языка ЗСН- оформляются 
в виде модулей с расширением .рг$, а команды языка сІВАЗЕ 
в виде модулей с расширением .ргд. Переключение с одного 
языка на другой в ходе выполнения прикладной программы 
осуществляется автоматически в зависимости от исполняемого 
модуля. 

В командном режиме язык ЗСН. устанавливается командой 
сІВАЗЕ ЗЕТ 501 ОИ, а возвращение в сІВАЗЕ осуществляется 
командой $ЕТ 501 ОРР. Можно назначить режим ЗСН. по 
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умолчанию в файле СопІід.сІЬ, введя $ОІ. = ОИ или 
СОММАЫО = ЗЕТ 501 ОИ. 

Эффективное выполнение команд языка 501- реализуется 
благодаря хранению специальной ссылочной информации на 
каждую таблицу и выборку. Эта информация содержится в 
файлах, называемых каталогами таблиц, которые формируются 
при создании БД командой 501. СКЕАТЕ РАТАВАЗЕ. 

На языке $ОІ-, как и на сІВАЗЕ IV, обеспечивается одно¬ 
пользовательский и многопользовательский (сетевой) режимы 
работы. В ходе выполнения ввода, обновления или удаления 
данных автоматически осуществляется захват данных в таблицах 
ЗОІ-. Если операция не может быть выполнена ввиду захвата 
данных другим пользователем, целесообразно в программу 
включать команды повторного захвата. Кроме того, работая на 
языке 301- в среде ЛВС, можно на языке сІВАЗЕ выполнять 
специальные команды по защите файлов БД, например, 
команды транзакции ВЕСІЫ ТКАИЗАСТЮИ и ЕИР ТКАЫЗАСТІОМ 
Если операция не завершается успешно, то, как и на языке 
сІВАЗЕ IV, можно восстановить БД в исходное состояние с 
помощью команды коиваск. 

Команды языка 301. в командном режиме вводятся, как и 
команды сІВАЗЕ, в нижней строке экрана после приглаше¬ 
ния - слова .301. - или в окне, которое вызывается нажатием 
клавиш СігІ-Ноте. В нижней строке экрана размещается до 254 
символов, а в окне при записи в несколько строк до 1024 
символов. Команду 501- нужно завершить точкой с запятой и 
нажать для выполнения клавишу Епіег при вводе в нижней 
строке экрана или клавиши С1Н-Еп4 при вводе в окне. 

Напомним, что точка с запятой используется также в 
программах на языке сІВАЗЕ IV для обозначения продолжения 
команды на следующей строке. 

При наборе в окне после нажатия клавиш СігІ-ЕпсІ команда 
высвечивается в нижней части экрана после слова .ЗОЕ и затем 
выполняется. 

Каждая команда языка 301- (называемая также предло¬ 
жением) начинается глаголом, определяющим имя базовой 
операции. В состав многих команд входят ключевые слова и 
предложения (команды), уточняющие выполнение базовой 
операции. Кроме того, в команде 501. нужно определить 
данные, которые будут обрабатываться (множество строк в 
одной или нескольких таблицах), и операцию, которую требует¬ 
ся над ними выполнить. 

В командном режиме можно получить справочную инфор¬ 
мацию по использованию команд языка ЗСН. и допус* имых 
команд сІВАЗЕ IV, набрав команду НЕІ.Р. Высвечивается 
меню - содержание справочной информации, в котором 
предлагается выбор тем: 301- Іегѵпз (термины ЗОІ_), ІІзіп') 301 
(использование 301.), 301. соттапсіз (команды ЗОІ_), сІВАЗЕ 
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соттапсіз іп 5СИ (команды сІВАЗЕ в ЗСН.), Но\ѵ іо изе Неір 
(как пользоваться справочником), Ехіііпд ЗОЕ (выход из 501_). 
После выбора темы высвечивается информация, которая 
может располагаться на нескольких экранах. 

Движение вперед по экранам выполняется клавишей Р4, 
а назад - клавишей РЗ. Внизу экрана имеется горизонтальное 
меню с позициями: СОИТЕИТЗ (содержание), КЕ1.АТЕ0 ТОРІСЗ 
(связанные темы), ВАСКІІР (возвращение) и РКІЫТ (вывод на 
печать). 

Можно получить справочную информацию по конкретной 
команде, если после команды НЕІ.Р набрать глагол этой 
команды или набрать только глагол команды и нажать 
клавишу Р1. 

Если выполняемая команда 5СН_ содержит синтаксические 
ошибки, то высвечивается окно с сообщением об ошибке и 
горизонтальное меню с позициями: СапсеІ (прекратить 

выполнение), ЕсІгГ (редактировать команду) и Неір (справочная 
информация). 

Язык ЗОЕ оперирует с понятием БД, которая содержит всю 
информацию, необходимую для обработки данных в прикладной 
программе. В состав БД ЗОЬ входят следующие компоненты: 

таблицы - основные структуры данных в БД; 

выборки - тип виртуальной таблицы, которая обеспечивает 
ввод и вывод определенных строк и колонок из одной или 
более таблиц; 

синонимы - альтернативные имена таблиц и выборок; 

индексы - файлы, присоединяемые к таблицам для обеспе¬ 
чения более быстрого поиска данных и поддержки целостности 

БД; 

каталоги - множество таблиц в каждой БД, которые 
описывают БД и ее содержимое. 

Перед созданием или использованием таблиц 501- необходи¬ 
мо создать или активизировать существующую БД. Каждая БД 
хранится в определенном директории вместе с таблицами и 
связанными файлами, включая каталоги таблиц. В каталогах 
таблиц содержится информация о базовых таблицах, выборках, 
индексах и синонимах, а также данные по защите информации 
и по операциям, выполненным над таблицами и другими 
файлами в этой БД. 

Главный каталог таблиц ЗузсІЬз содержит данные о всех БД, 
созданных пользователями, включая имя БД, местоположение на 
диске (маршрут по директориям), имя пользователя, создав¬ 
шего БД (имя пользователя в ЛВС), и дату создания БД. Файл 
главного каталога таблиц ЗузсІЬз размещается в том же 
директории, что и системные файлы ЗОЬ. 
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4.2. КОМАНДЫ СОЗДАНИЯ БАЗ ДАННЫХ И ТАБЛИЦ 501. 

В языке 5СЯ сіВАЗЕ IV имеется пять команд, связанных с 
созданием и использованием БД: СКЕАТЕ РАТАВАЗЕ, 5НО\Ѵ 
РАТАВА5Е, 5ТАКТ РАТАВАЗЕ, ЗТОР РАТАВАЗЕ и РКОР РАТА- 
ВАЗЕ. Создание БД осуществляется только в режиме набора с 
клавиатуры командой 

СНЕ АТЕ РАТАВА5Е [<путь по директориям >] <имя БД>; 

которая открывает в текущем директории или в директории, 
заданном маршрутом, поддиректорий с именем БД. В этом 
поддиректории формируются таблицы каталога, в которые 
помещаются данные о всех создаваемых в данном поддиректо¬ 
рии таблицах $ОІ_. Имя БД, пользователя, создавшего БД 
(в среде ЛВС), дата создания и маршрут по директориям этой 
БД помещаются в главный каталог ЗузсІЬз. 

Таким образом, БД 501- - это специально созданный 

директорий, в котором размещается каталог таблиц, созданных 
в этом директории, таблицы и другие 'связанные с ними файлы. 
Имя БД должно быть уникальным. Если при открытии БД уже 
существует директорий с таким же именем, то этот директорий 
определяется как БД 501- и в нем размещаются все компонен¬ 
ты БД. В каждый текущий момент может быть открыта только 
одна БД, в которую вводятся создаваемые таблицы. Поэтому, 
если требуется открыть другую БД, надо предварительно 
закрыть текущую. 

Закрытие БД выполняется командой ЗТОР РАТАВАЗЕ. 
Активизация (открытие) имеющейся БД осуществляется 
командой ЗТАКТ РАТАВАЗЕ [<имя БД>];. При этом БД, ранее 
открытая и не закрытая в момент активизации другой БД, 
автоматически закрывается. После этого можно выполнять любые 
команды 501- по определению таблиц, поиску данных и т.д. 
Для удаления БД используется команда РКОР РАТАВАЗЕ <имя 
БД>;. Эта команда удаляет закрытую БД, а также все ее 
компоненты (в том числе связанные файлы .4Ы и .тсіх), 
каталоги таблиц и данные об этой БД в главном каталоге 
таблиц ЗузсІЬз. При выполнении команды высвечивается преду¬ 
преждение о выполнении операции удаления. Для подтвержде¬ 
ния нужно дать ответ V или Ѵе$. Операцию можно отменить 
нажатием клавиши Е$с. 

Удалять можно только закрытые БД, поэтому перед 
удалением БД целесообразно выполнить команду ее закрытия 
5ТОР РАТАВАЗЕ. Для просмотра всех созданных БД использу¬ 
ется команда $НО^ 0АТАВА5Е, высвечивающая список имен БД 
в текущем директории, имя создавшего БД пользователя 
(в среде ЛВС), дату создания и маршрут по директориям. 
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4.3. ТАБЛИЦЫ $СИ 

Таблицы представляют собой основной компонент БД $СН_, 
в которых определяется структура данных. Структура таблицы 
задается командой СКЕАТЕ ТАВІ.Е и может быть впоследствии 
модифицирована (добавлены колонки) командой АІ.ТЕК ТАВІ.Е. 
Команды 1№ЕКТ, ЦРРАТЕ и РЕІ.ЕТЕ позволяют добавлять, 
изменять или удалять данные из таблиц. 

В сІВАЗЕ IV имеются утилиты, позволяющие импортировать 
внешние файлы в файлы 501. (вводить и добавлять в таблицы 
данные из не-5СН. файлов) и экспортировать файлы $ОІ_. 

Команда РВРЕРІЫЕ дает возможность использовать в $ОІ_ 
файлы сІВАЗЕ IV, команда ЮАР РАТА - импортировать файлы 
сІВАЗЕ II, сІВАЗЕ III и сІВАЗЕ III + , данные из электронных 
таблиц І_оіи$ 1-2-3, МиЖРІап и Ѵізісаіс, файлы АЗСІІ и 
файлы с разделителями, базы данных и электронные таблицы 
Ргатеѵѵогк II и КарісіРіІе. Команда ІРИЮАО РАТА экспортирует 
таблицы 5СЛ. в эти типы файлов. 

Для создания новой таблицы 5СІІ_ и определения типов 
данных используется команда 

СКЕАТЕ ТАВ1.Е <имя таблицы > 

(<имя колонки >< тип данных > 

[,< имя колонки><тип данных 

Пример: 

СКЕАТЕ ТАВІ_Е Іфгі 

(ТаЬ_по СНАК(4), 

Рат СНАК(15), 

Эа1_гаЬ ЭАТЕ, 

Асігез СНАК(ЗО). 

Ок 1 ас! 0ес1гпа1(4,0), 

Ргетп Эесішаі (4,0)); 

Ниже приводятся типы данных, разрешенные для использо¬ 
вания в таблицах ЗОІ_: 

ЗМАШНТ - целые числа до 6 значащих цифр, включая 
знак. Диапазон от -99,999 до 999,999; 

ІЫТЕСЕК - целые числа до 11 значащих цифр, включая 
знак. Диапазон от -9,999,999,999 до 99,999,999,999; 

РЕСІМАЦх.у) - числа с фиксированной десятичной точкой 
с х (от 1 до 19) позициями (включая знак числа) и у (от 
О до 18) дробными позициями справа от точки. Например, 
РЕСІМАЦ6,2) позволяет вводить числа без знака до 9999.99 и 
числа со знаком от -999.99 до 9999.99; 

И11МЕК1С(х,у) - числа с фиксированной десятичной точкой 
с х (от 1 до 20) позициями (включая знак числа и десятич¬ 
ную точку) и у (от 0 до 18) дробными позициями справа от 
точки. Например, МСІМЕКІС(6,2) позволяет вводить числа без 
знака до 999.99 и числа со знаком от -99.99 до 999.99; 
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РЮАТ(х,у) - числа с плавающей точкой с х (от 1 до 20) 
позициями (включая знак числа и десятичную точку) и у (от 
0 до 18) дробными позициями справа от точки. Диапазон от 0.1 
х 10 ЕХР(-307) до 0.9 х ЕХР( + 308) (например, -9.99Е + 235); 

СНАВ(п) - строка из п (до 254) символов. В колонку с 
этим типом данных могут вводиться данные из символьных 
колонок, символьных переменных и символьных строк; 

ОА1Е - дата в формате, определенном командами 5ЕТ 
йАТЕ и $ЕТ СЕМТІЖѴ (по умолчанию формат тт/сісі/уу). Дан¬ 
ные могут вводиться из колонок и переменных с этим же 
типом или из строк, заданных в виде { / / }, и строк, 
преобразованных СТОО(), например СТОО("02/15/89"); 

ЮСІСАІ. - логические значения .Т. (истина) и .Р. (ложь). 
Значения могут вводиться из логических переменных или 
колонок или в виде констант .Т., .1, .У., .у., .Р., 

.Ы., .п.. 


4.4. ВВОД, ОБНОВЛЕНИЕ И УДАЛЕНИЕ ДАННЫХ, 

МОДИФИКАЦИЯ ТАБЛИЦ И СОЗДАНИЕ ВЫБОРОК 

Для ввода новых строк данных используются команды 
1№ЕВТ и І.ОАО РАТА. Ввод конкретных значений в заданные 
колонки таблицы выполняется командой 

1№ЕВТ ІНТО <имя таблицы> 

[(< список колонок >)] 

ѴАШЕ$( < список значений >); 

Пример: 

ІИЗЕКТ ІИТ0 Цргі 

ѴАІ_иЕ$ ( м 0112", -Петров”, {20/10/89},300); 

Если список колонок опущен, то значения вводятся по 
порядку во все колонки. 

Для ввода отобранных строк из существующей таблицы 
используется предложение 5ЕІ.ЕСТ: 

1№ЕВТ ІИТО <имя таблицы > 

[(< список колонок > )] 

< предложение $ЕІ.ЕСТ>; 

Предложение 5ЕІ.ЕСТ представляет собой команду для 
извлечения данных из заданных колонок таблицы в соответствии 
с заданным условием 

ЗЕІ.ЕСТ < колонки > 

РВОМ < таблицы > 

[У/НЕВЕ < условие > ]...; 
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Пример: 

ІИЗЕЯТ ШО ІІргІ 
ЗЕЬЕСТ * 

РВОМ Црг2 

ѴНЕВЕ ТаЬ_по> 0112 

Символ * обозначает, что в предложении 5ЕІ.ЕСТ выбира¬ 
ются все колонки таблицы Ц1рг2. 

Для изменения значений строк в таблице в соответствии с 
заданным условием используется команда 

ЦРРАТЕ <имя таблицы > 

$ЕТ <имя колонки > = < выражение > 

[,<имя колонки> = < выражение>...] 

[МЖЕВЕ < условие > ]; 

Пример: 

0Р0АТЕ Ургі 

$ЕТ Ргеш = Ргет * 1.3 

УНЕВЕ Ра*_гаЬ < СТ00 (”01/01/75”); 

Удаление строк таблицы по заданному условию можно 
выполнить командой 

ОЕЬЕТЕ РВОМ <имя таблицы > 

[^НЕВЕ < условие >]; 

Пример: 

0Е1_ЕТЕ РВОМ Цргі 
ѴНЕВЕ Раш * "Котов"; 

В языке 5СН. можно добавлять колонки в существующую 
таблицу, но нельзя их удалять или изменять. Для модификации 
таблиц целесообразно создать новую таблицу и затем ввести в 
нее строки из существующей таблицы. 

Добавление колонок в существующую таблицу выполняется 
командой 

ЛИЕВ ТАВІ.Е <имя таблицы > 

АОО (<имя колонки > <тип данных > 

[ г < имя колонки><тип данных 

Пример: 

АНЕВ ТАВІЕ Црг1 
А00 (ТеІеРоп СНАВ(9)); 

Для создания выборки с заданным именем и именами 
колонок используется команда 

СВЕАТЕ ѴІЕѴ <имя выборки > 

[(<список колонок выборки >)] 

А$ < предложение $ЕІ.ЕСТ> 

[^ІТН СНЕСК ОРИОН]; 
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Пример: 

СКЕАТЕ ѴІЕУ ОгсІ 

А$ 5Е1.ЕСТ ТаЬ_по, Рат, Окіасі 

РКОМ Цргі 

УНЕКЕ Асігез * "Ордынка" 

Если список колонок выборки не указан, то имена выбира¬ 
ются из списка в предложении 5Е1.ЕСТ, которое определяет 
строки и колонки из таблицы, включаемой в выборку. 

Опция ѴПТН СНЕСК ОРТІОИ используется для выборок, 
которые могут обновляться, и устанавливает, что вводимые или 
обновляемые строки должны проверяться на соответствие с 
заданными условиями. Например, эта опция позволяет запретить 
ввод или обновление строк выборки, которые не удовлетворяют 
условию, заданному в предложении 5ЕК.ЕСТ (с ключевым 
словом Ѵ^НЕКЕ). 

Выборки позволяют реконструировать данные в БД, не 
прибегая к созданию новых таблиц или модификации старых. 
Как уже указывалось, выборки фактически не содержат данных 
и поэтому занимают значительно меньше места в памяти, чем 
таблицы. Можно создать несколько выборок по одной таблице, 
отражающих все изменения, сделанные в таблицах. 

Можно создавать выборки из нескольких таблиц. Для этого 
в предложении А$ 5Е1.ЕСТ указываются имена колонок из 
различных таблиц в виде <имя таблицы >.< имя колонки > 
[,<имя таблицы > .<имя колонки >]... 

Пример: 

СКЕАТЕ ѴІЕУ Іака* 

(2ак_по, Оа*_ргогі, Мадагіп) 

А$ 5Е1.ЕСТ РгосІапо.2ак_по, Ргосіапо.Оа*_ргогі, 

Ургаѵі.Ріо 

ГРОМ Ргогіапо, иргаѵі 

УНЕКЕ Ргосіапо.ирг_по = ІІргаѵІ .Ург по 

Удаление выборки осуществляется командой 

ОКОР ѴІЕѴ^ <имя выборки >; 

В язык 501- включены синонимы, которые замещают имя 
таблиц или выборок в командах. Синонимы создаются командой 

СКЕАТЕ ЗУИОИУМ <имя синонима > 

РОК <имя таблицы или выборки >; 

Синонимы используются в любых командах вместо имени 
таблицы или выборки с целью сокращения имени записи, 
например, в командах 5ЕІ.ЕСТ, СКЕАТЕ 1№ЕХ, ІИ5ЕКТ, ІДОАТЕ, 
0Е1Е1Е и РКОР. 

Одной из важнейших характеристик любой БД является 
способность быстро находить нужную информацию. Индексные 
файлы (индексы) представляют собой одно из средств для 
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быстрого поиска данных в БД 5С5І-. Индексные файлы содержат 
информацию о расположении строк в БД 5СН. в соответствии 
с их значениями колонок. В отличие от индексов языка 
СІВА5Е IV в языке 5СН. не требуется указывать индекс для 
поиска данных. В режиме $ОЬ автоматически выбирается тот 
индекс, который обеспечивает наиболее быстрый поиск. Индексы 
строятся только для таблиц, но не для выборок. Однако при 
работе с выборками обычно используются индексы, построенные 
для соответствующих таблиц. 

Индексы для БД 501- представляют собой указатели в 
множественном индексном файле .тсіх, который имеет то же 
имя, что и таблица $01_. Для каждой таблицы БД можно 
создать до 47 указателей индексов. Для создания индекса 
используется команда 

СВЕАТЕ [ІЖІСШЕ] ІЫРЕХ <имя индекса> 

ОИ <имя таблицы > (<имя колонии > [А5С/РЕ5С] 
[,<имя колонки > [А5С/РЕ5С]...); 

Указатели индексов создаются для заданных имен колонок. 
Имена колонок могут занимать не более 100 позиций в строке 
команды. 

Опция ІІИЮІІЕ определяет уникальный индекс, т.е. в индекс 
включаются уникальные значения колонок. При вводе или 
обновлении данных в таблицу с уникальным индексом записыва¬ 
ются только уникальные значения. При создании индекса 50Ь 
таблицы связанный с ней файл БД сІВАБЕ IV можно только 
читать. 

Опции А5С/РЕ5С определяют порядок построения индекса 
соответственно по возрастанию (по умолчанию) или убыванию. 

Индексы можно создавать по всем полям, кроме логичес¬ 
ких. 

Удаление индексов осуществляется командой 

РВОР ІИРЕХ <имя индекса>; 

Как уже указывалось выше, вся информация о компонентах 
БД 501- (таблицы, выборки, синонимы, индексы) хранится в 
системных каталогах. Каталог $у$ІаЬІ5 представляет собой 
таблицу с колонками, в которых содержится информация о 
существующих таблицах (ТЬпате) и их типах (ТМуре). Для 
вывода информации из этого каталога можно использовать 
команду 

5ЕІ.ЕСТ ТЬпате, ТЫуре 
РВОМ 5у$іаЫ$; 

В поле ТЫуре указывается тип таблиц данных: базовая 
таблица (Т), выборка (V) или временная таблица (Р или К). 
Информация о колонках таблиц хранится в каталоге $у$соІ$ с 
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колонками Соіпате (имя колонки), Соііуре (тип колонки), 
СоІІеп (ширина колонки), которую можно извлечь командой 


5ЕІ.ЕСТ Соіпате, Соііуре, СоІІеп 
РКОМ $у5СОІ5 

УЖЕКЕ ТЬпате = <"имя таблицы" >; 


4.5. ЗАПРОСЫ НА ИЗВЛЕЧЕНИЕ ДАННЫХ В ЯЗЫКЕ 501. 

Большинство запросов на извлечение данных из БД 5СН. 
строится на основе команды 5ЕІ.ЕСТ. Синтаксис этой команды 
позволяет создавать простые по конструкции предложения для 
реализации сложных запросов на извлечение, ввод и удаление 
данных: 

5ЕІ.ЕСТ < предложение > 

[ІЫТО <предложение>] 

РВОМ < предложение > 

[>У НЕКЕ < предложение > ] 

[СКОІІР ВУ < предложение >] 

[НАУІИО <предложение>] 

[ЦтОИ 5ЕІ.ЕСТ <предложение>]... 

[ОКРЕП ВѴ < предложение > 

/РОК ЫРРАТЕ ОР < предложение >] 

[$АѴЕ ТО ТЕМР < предложение >]; 

Выше уже рассматривалась простейшая форма этой команды 
5ЕІ.ЕСТ <колонки> РКОМ <таблицы>;. 

Итогом выполнения команды 5Е1.ЕСТ является результирую¬ 
щая таблица, которую можно сохранить командой 5АУЕ ТО 
ТЕМР. Можно также сохранить ее в виде файла .бЫ с помо¬ 
щью опции КЕЕР. В качестве заголовков колонок этой таблицы 
используются имена колонок, из которых извлекались данные. 
Если информация выбиралась из нескольких таблиц (указывется 
в предложении РКОМ), то перед именем колонки в результиру¬ 
ющей таблице ставится имя таблицы, из которой выбирались 
данные. При выводе больших таблиц можно устанавливать 
команду $ЕТ РАІІ5Е ОМ, позволяющую выводить данные 
страницами экрана. Кроме этого, для остановки и возобновления 
вывода на экран данных (при повторном нажатии) можно 
использовать клавиши СГН-$. Для уменьшения ширины выводи¬ 
мой на экран колонки целесообразно использовать в предложе¬ 
нии РКОМ вместо ее имени алиасы или синонимы, поскольку 
минимальная ширина выводимой колонки определяется ее 
именем. Кроме того, можно вообще удалить имена колонок, 
используя команду $ЕТ НЕА0ІЫС5 ОРР. Как уже упоминалось 
выше, для высвечивания всех колонок таблицы нужно в команде 
вместо имен колонок поместить символ (*): 
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5ЕІ.ЕСТ * 

РКОМ <имя таблицы >; 

Для того чтобы вывести только уникальные строки таблицы, 
не повторяющиеся в заданных колонках, используется ключевое 
слово 0І5ТІИСТ: 

5ЕЫЕСТ РІ5ТІЫСТ <колонки> 

РВОМ <имя таблицы >; 

Пример: 

$ЕІ_ЕСТ 0І5ТІЫСТ 0е1_по, Орізапіе 

РКОМ Оеіаі; 

Для отбора строк по заданному критерию используется 
предложение >ѴНЕКЕ: 

5Е1.ЕСТ < колонки > 

РВОМ <имя таблицы > 

>АЖЕВЕ < условие >; 

Пример: 

ЗЕЬЕСТ Оеѣ по, Орізапіе, Зкіасі, Асігез, Ко1_сіе* 

РКОМ Міо 

Ѵ/НЕКЕ Асігез = "Минск”; 

В состав критерия отбора, как и в языке СІВА5Е IV, могут 
входить элементарные логические условия и сложные, в которых 
элементарные условия объединяются логическими связками. 
Элементарное логическое условие строится по форме 

<имя колонки><оператор отношения ><значение > 

В языке 5СН_ используются те же операторы отношений, что 
и в с)ВА5Е IV, за исключением оператора отрицания, который 
в 5СН. обозначается символом !. 

Содержимое колонки и сравниваемого значения должны 
быть одного типа. Все числовые типы данных могут сравнивать¬ 
ся между собой. Символьные константы должны заключаться в 
двойные или одинарные кавычки. Сравнение символьных данных 
между собой выполняется по их ' кодам А5СІІ, что следует 
учитывать при сравнении прописных и строчных букв. При 
формировании элементарного условия для логического типа 
данных можно не использовать оператор и значение. В этом 
случае по умолчанию предполагается оператор ( = ) и 
значение .Т. 

Пример: 

5Е1.ЕСТ * 

РКОМ 2акагу 

Ѵ/НЕКЕ Оідгигка = Л.; 
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Последний оператор можно записать в виде 
Оідгиіка. Имя в элементарном логическом условии можно 
использовать как аргумент в функциях, допустимых в $ОІ_, 
например, в функции УРРЕК() для преобразования строчных 
букв в прописные. Выше приводился пример использования 
функции стсюо для преобразования строки типа даты при 
сравнении с колонкой типа даты. 

В качестве логических связок используются операторы ИОТ 
(НЕТ), АИй (И) и ОВ (ИЛИ). Заметим, что в отличие от 
языка сІВАЗЕ IV перед и после этих операторов не ставятся 
точки. Сложные логические условия оцениваются по правилам 
булевой алгебры. При оценке последовательности элементарных 
логических условий с логическими связками высший приоритет 
имеет оператор НОТ, затем АЫй и ОК. 

В состав предложений ЗЕІ.ЕСТ, Ѵ/НЕВЕ и НАѴІЫС могут 
входить выражения, включающие имена колонок, константы, 
переменные, математические операторы (те же, что и в 
сІВАЗЕ IV) и функции. В предложении 5ЕІ.ЕСТ можно задавать 
вывод символьного выражения, а также вычисляемую колонку. 
Вычисляемые колонки имеют заголовки с именами ЕХР1, ЕХР2 
и т.д. в соответствии с порядком их определения в предложе¬ 
нии 5ЕІ.ЕСТ. 

Пример: 

5Е1.ЕСТ ТаЬ_по, Раш, "Оклад+премия", Окіасі+Ргеш 

В этом примере вычисляется сумма оклада и премии 
(Окіас) + Ргет), которая выводится с заголовком ЕХР2 и перед 
этой колонкой выводятся слова Оклад + премия в каждой строке 
с заголовком ЕХР1. 

В условия, задаваемые в предложении >УНЕКЕ (включая 
предикаты ВЕТЛУЕЕИ, ІИ и ЫКЕ), также могут входить выра¬ 
жения. 

Кроме констант, значений колонок и математических 

операторов в состав выражений могут входить многие функции, 
определенные в сІВАЗЕ IV. Вместе с языком ЗОЬ используется 
их свыше 100. При этом необходимо указывать полное имя 

функции. 

Кроме функций из языка сІВАЗЕ IV в 501. входят специаль¬ 
ные функции агрегирования, которые используются в команде 

ЗЕІ.ЕСТ: 

соиитп - определяет количество отобранных строк; 

- суммирует значения числовых колонок; 

міио находит минимальное значение символьных, 

числовых и колонок типа даты; 

МАХ() находит максимальное значение символьных, 

числовых и колонок типа даты; 

аѵсп - вычисляет среднее значение числовой колонки. 
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При использовании с символьными колонками функции 
МІЫ() и МАХ() возвращают данные с минимальным и 
максимальным значениями кодов АЗС II строк. Сравнение 
выполняется с первого символа слева. В выражениях колонки 
должны быть одного типа. Все числовые типы данных могут 
использоваться совместно. Символьные константы должны 
заключаться в одинарные или двойные кавычки. 

Функции агрегирования могут включаться в команду 5Е1.ЕСТ 
вместо имен колонок. 

Примеры: 

ЗЕЬЕСТ С0Ш(*) 

РВОМ ІІргІ; 

5ЕІ-ЕСТ ЗІІМ (Ок 1 асі ) 

РКОМ ІІргІ ; 

8ЕІ.ЕСТ МАХ(ОкІасі) г МІИСОкІагі), АѴб(ОкІасі) 

РЛОМ ІІргІ; 

При выводе значений функций агрегирования сверху 
высвечивается наименование функции и порядковый номер, 
указывающий ее позицию в предложении 5ЕІ.ЕСТ. Символ * в 
функции СОІІЫТО указывает на подсчет по любой колонке. В 
предложении >ЛЖЕКЕ могут использоваться предикаты ВЕ1ЛУЕЕЫ, 
ІИ и ИКЕ, которые позволяют записывать условие в более 
компактном виде. 

Предикат ВЕІЛА^ЕЕИ определяет диапазон поисковых 
значений. Например, вместо записи условия ѴѴНЕкЕ ОкІасІ > = 
300 АЫй ОкІасІ < = 500 можно записать ѴѴНЕкЕ ОкІасІ 
ВЕТ\ѴЕЕІЧ 300 АІЧЭ 500. Этот предикат указывает закрытый 
интервал значений. 

Предикат ІИ проверяет, находится ли значение колонки 
среди указанных в списке. Например, вместо записи условия 
ѴѴНЕкЕ $окг = “АБ“ Ок “ВГ“ Ок “ДЕ” можно записать ѴѴНЕкЕ 
$окг ІЫ ( “АБ“, “ВГ”, “ДЕ”). 

Предикат ЫКЕ осуществляет поиск на включение подстроки, 
задаваемой в переменной или в виде константы. Подстрока 
определяется заданными символами, окруженными символами 
замещения (_) и (%). Первый из них замещает один символ, 
второй любое число символов. 

Пример: 

5ЕІ.ЕСТ ТаЬ_по, Раш, ОкІасІ 

РК0М ІІргІ 

ѴНЕКЕ Раш ИКЕ и ПетХ”; 

Как и обычные условия, в предложении >ѴНЕКЕ предикаты 
ВЕІЛА^ЕЕИ, ІИ и ИКЕ могут объединяться логическими связками 
АИР, Ок и ИОТ. При объединении допускаются скобки для 
облегчения построения сложных условий. 
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При отборе строк из таблицы они обычно выводятся в том 
порядке, в котором создана таблица. Для изменения порядка 
выводимых строк используется предложение О&ОЕК ВѴ: 

5ЕІ.ЕСТ < колонки > 

РВОМ < таблицы > 

ѴЖЕВЕ < условие > 

ОВОЕК ВѴ < колонка/целое число> [А$СД)Е$С] 
[,< колонка/целое число > [А5С/ОЕ5С]...]; 

Колонки, используемые в предложении ОВОЕВ ВѴ, должны 
быть включены в предложение 5ЕІ.ЕСТ. В предложении ОВРЕВ 
ВѴ вместо имен колонок можно ставить целые числа, определя¬ 
ющие их позицию в предложении 5Е1.ЕСТ. Для ускорения 
извлечения данных целесообразно командой СВЕАТЕ ІЫРЕХ 

создавать индексы по поисковым колонкам. Ключевые слова 

А$СЛ>Е$С указывают на упорядочение по возрастанию или 
убыванию. 

При упорядочивании таблицы более чем по одной колонке 
строки располагаются в порядке, определяемом первой 
колонкой. Строки с одинаковым значением этой колонки 

располагаются в порядке, определяемом второй колонкой, и т.д. 

Два дополнительных предложения СВОІІР ВѴ и НАѴІЫО 
позволяют располагать строки по группам. Затем можно 

выполнять операции с этими группами, например используя 
функции агрегирования. Предложение СВОІІР ВѴ позволяет 
объединить строки результирующей таблицы, определяемой 
предложением 5Е1.ЕСТ, в группы с одинаковым значением 
заданных колонок. После агрегирования каждая такая группа 
сводится к одной строке в результирующей таблице. В качестве 
имени колонки с результатом агрегирования используется имя 
функции агрегирования с порядковым номером этой функции. 

Пример: 

5Е1.ЕСТ 0е1_по, Орізапіе, Ко1_гіеі 

ГРОМ Міо 

6К01ІР ВУ Ое*_по, Орізапіе; 

Существуют два ограничения при использовании предложе¬ 
ния СВОЫР ВѴ. Во-первых, все колонки, указанные в предложе¬ 
нии 5ЕІ.ЕСТ, должны быть включены в предложение СВОІІР ВѴ 
и наоборот. Во-вторых, в предложении СВОІІР ВѴ нельзя 
указывать вычисляемую колонку за исключением имен колонок, 
использованных в функциях агрегирования в предложении 
5ЕІ.ЕСТ. 

Пример: 

5Е1.ЕСТ ОЫаз*, С01Ш(*) 

ЕРОМ Мазеіепіе 

6К0иР ВѴ ОЫазѣ ; 


299 



В этом примере подсчитывается количество жителей в 
областях. 

Предложение СКОЦР ВѴ может использоваться совместно 
с предложением ОКРЕК ВУ для обеспечения упорядоченного 
расположения выводимых строк по заданной колонке. 

Пример: 

ЗЕ1.ЕСТ Ое*_по, Орізапіе, $шп(Ко1_гіе*) 

ГНОМ Зкіасі 

6КСШР ВѴ Орізапіе,Ое*_по 

ОКОЕК ВѴ Орізапіе; 

Предложение НАѴІЫО, используемое вместе с предложе¬ 
нием СКОЦР ВѴ, позволяет отобрать в состав групп строки, 
удовлетворяющие заданным условиям. Действие предложения 
НАѴІИС аналогично предложению ѴЖЕКЕ, но определяет 
условие, которому должна удовлетворять каждая группа для 
вывода в результирующую таблицу. Например, для вывода 
упорядоченного по алфавиту перечня деталей стоимостью более 
300 руб., которых на складе больше 10, можно использовать 
следующую команду 5Е1.ЕСТ: 

ЗЕІ.ЕСТ Орізапіе, Иошег, $1Ж (Коі ісИезѣѵо) , $Іо1тозѣ 

ГРОМ Зкіасі 

ѴНЕКЕ Зіоітозі > 300 

вКОІІР ВѴ Орізапіе, ^тег, Біоітозі: 

НАѴIN6 51Ж (КоІІсНезІѵо) > 10 

0К0ЕК ВѴ Орізапіе; 

Если предложение НАѴІЫС используется без предложения 
СКОІІР ВѴ, то его действие распространяется на всю результи¬ 
рующую таблицу и эквивалентно предложению >ѴНЕКЕ. 

В языке 501_ имеется еще один способ реализации сложных 
запросов - с помощью команды ІІЫІОИ. Эта команда позволяет 
объединить результирующие таблицы, получаемые в результате 
выполнения нескольких команд 5ЕІ.ЕСТ, удаляя при этом все 
дублируемые строки и оставляя из них только одну. 

При этом результирующие таблицы из всех запросов 
должны быть совместимы, т.е. должны иметь одинаковое 
количество колонок и совместимые типы данных в соответствую¬ 
щих колонках. Имена колонок в каждом запросе могут быть 
различными. 

Для символьных колонок их ширина должна быть одинако¬ 
вой. Для числовых колонок должно быть определено 
одинаковое общее количество цифр, одинаковый тип числа 
(с фиксированной или плавающей точкой) и одинаковое число 
дробных знаков. 

Для упорядочивания результирующей таблицы после выпол¬ 
нения команд ІІНІОИ нужно включить предложение ОКРЕП ВѴ 
в последнюю команду 5ЕІ.ЕСТ. При этом в предложении ОКРЕП 
ВѴ для указания колонки, по которой упорядочивается результи- 
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рующая таблица, необходимо использовать число, определяющее 
позицию колонки в командах 5ЕІ.ЕСТ. Например, для выбора 
всех городов, в которых расположены заводы, поставщики и 
склады производственного объединения, можно использовать 
следующие команды: 

ЗЕІ.ЕСТ богогі 
РКОМ 2аѵо<* 

1Ш0И 

БЕІЕСТ Мез*о 
РКОМ РозіаѵсЫк 

инюи 

БЕІЕСТ Незіо 
РКОМ Бкіасі 

ОКОЕК ВТ 1; 


4.6. ИЗВЛЕЧЕНИЕ ДАННЫХ ИЗ НЕСКОЛЬКИХ ТАБЛИЦ 
И ВЛОЖЕННЫЕ ЗАПРОСЫ 

Команда БЕЫЕСТ позволяет выполнять запросы на выборку 
данных не только из одной таблицы, но и из нескольких 
таблиц. При этом используются те же самые предложения, что 
и при запросах из одной таблицы. В предложении РВОМ через 
запятую указываются имена таблиц. Если в нескольких таблицах 
имеются колонки с одинаковым именем, то тогда перед этими 
именами указываются имена таблиц, отделенные точкой. В 
случае, если требуется вывести все колонки какой-либо таблицы, 
можно вместо имен колонок в составном имени указать символ 
замещения *, например: ЗкІасІ.* (из таблицы с именем ЗкІасІ 
выводятся все колонки). 

Пример: 

БЕІЕСТ ЗкІаЛ.*, (КоІІсИезІѵо * Зѣоітозѣ) 

РКОМ ЗкІасІІ, Зкіасіг 

УНЕКЕ Зкіасіі.Оеіаі * 5к1асі2.0е*а1 А№ КоІІсНезІѵо > 10 

В этом примере выводятся все колонки таблицы ЗкІасІІ 
(склад N1 готовых деталей) и, кроме того, вычисляемая 
колонка - произведение количества имеющихся деталей на их 
стоимость. При этом отбираются те строки таблицы ЗкІасІІ, в 
которых совпадают значения колонки ОеіаІ (наименование 
детали) с аналогичной колонкой в таблице ЗкІасІ2 (склад N2 
готовых деталей) и их количество превышает 10 на обоих 
складах. В предложении МАНЕРЕ можно использовать функции 
сІВАЗЕ IV, например, функцию ІІРРЕК(), если названия деталей 
вводились как со строчной, так и с прописной буквы. 

В результирующей таблице данных, извлеченных из 
нескольких таблиц, выводятся составные имена колонок, которые 
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бывают весьма длинными. Напомним, что для уменьшения 
ширины выводимой колонки можно вместо имен колонок 
указывать их алиасы и синонимы. Кроме того, можно вообще 
удалить имена колонок командой 5ЕТ НЕЛОІИО ОРР. Колонки, 
представляющие собой функции агрегирования, имеют соответ¬ 
ствующие заголовки: АѴС, СОІІМТ, МАХ и 51ІМ с цифрой 
справа, определяющей позицию функции агрегирования в 
предложении 5ЕІ.ЕСТ. 

Заголовки колонок, в которых используются функции 
сІВАЗЕ IV, имеют имена соответствующих функций. Колонки, 
определенные в предложении СКОІІР ВѴ, выводятся с именами 
колонок, которым предшествует ©_. 

Пример: 

5Е1.ЕСТ 0еіа1 .Мошег, Орізапіе, С(ШТ(*) 

РВОМ Оеіаі, Ргосіапо 
Ѵ/НЕКЕ Реіаі .Иопіег=Ргосіапо.Нопіег 
6В01ІР ВѴ ОеѣаІ.Вошег, Орізапіе 
ОМЕК ВѴ Орізапіе; 

В этом примере выводятся строки таблицы йеіаі с колонка¬ 
ми С_ІЧотег (номер детали), О _ Орізапіе (наименование 
детали) и СОЦІЫТІ (количество проданных деталей), в которых 
количество проданных деталей определяется их подсчетом из 
таблицы Ргосіапо с помощью функции агрегирования СОІІЫТ по 
группам проданных номеров деталей. Результирующая таблица 
упорядочивается по наименованиям деталей. 

Для этого же примера можно показать использование 
предложения НАѴІЫ6, например, вывести только те детали, 
которых продано больше 10. Тогда следует добавить предложе¬ 
ние НАѴІ N0 СОІИЧТ(*) > 10. 

В следующем примере показывается выполнение запроса из 
трех таблиц: ЭеіаІ, Ргосіапо и Коти (кому продано). Из 
последней таблицы выводятся наименования организаций, 
купивших детали (колонка РокираіеІ), упорядоченные по 
алфавиту. 

Пример: 

5ЕIЕСТ Оеіаі .Иогпег , Орізапіе, РокираЪеІ 
ГРОМ Оеіаі, Ргосіапо, Коши. 

Ѵ/НЕВЕ йеіаі. Лотег=Ргосіапо. Мошег 
АМ Ргосіапо.Рокира*е1=Коти.РокираІе1 
ОКОЕК ВѴ Коти.РокираЪеІ 

Использование алиасов (альтернативных имен) таблиц 
позволяет выполнять запросы, в которых в предложении ѴЖЕКЕ 
в левой и правой части условия можно ставить колонки одной 
таблицы. Это дает возможность осуществлять поиск в таблице 
по условию, включающему значения из нескольких колонок этой 
таблицы. 
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Например, имеется таблица Касігу, в которой размещены 
данные о кадрах предприятия с колонками Ыогпег (персональ¬ 
ный номер по учету кадров), Рат (фамилия работника) и 
Кигаіог (персональный номер наставника, который курирует 
работника). Требуется вывести список всех работников предприя¬ 
тия и их кураторов. Для этого можно использовать команду 

5ЕІ.ЕСТ каЬоІпІк.Раш, НазІаѵпІк.Рат 
РкОМ Касігу каЬоІпІк, Касігу Иазіаѵпік 
ѴНЕкЕ ИазІаѵпІк.КигаІог - каЬоІпІк.Ііотег 
ОкОЕк ВУ каЬоІпІк.Рат; 

Если требуется в первой колонке вывести кураторов, во 
второй слово "курирует", а в третьей работников и упорядочить 
кураторов по алфавиту, то команда будет выглядеть так: 

$ЕІ_ЕСТ ИазІаѵпік.Рат, "Курирует", каЬоІпІк.Раш 
РкОМ Касігу каЬоІпІк, Касігу Ііазіаѵпік 
ѴНЕкЕ Иазіаѵпік.Кигаіог = каЬоІпІк.Иошег 
ОкЭЕк ВУ НазІаѵлік.Ратл; 

В состав условий в предложении УЖЕКЕ (или НАѴІЫС) 
могут входить команды 5ЕІ.ЕСТ, образуя вложенные запросы. 
Команда 5ЕІ.ЕСТ в предложении УЖЕКЕ представляет собой 
внутренний запрос. Данные, полученные после выполнения 
внутреннего запроса, затем используются для выполнения 
внешнего запроса. 

Конструкция внешнего запроса зависит от количества 
значений, возвращаемых внутренним запросом. Могут быть 
два случая: внутренние запросы возвращают одно значение 

или несколько значений (более одной строки значений одной 
колонки). 

Существует два основных типа вложенных запросов: простые 
и коррелированные. В простых вложенных запросах внутренний 
запрос выполняется независимо от внешнего запроса и его 
результаты используются для выполнения внешнего запроса. В 
коррелированном вложенном запросе внутренний запрос 
обращается одновременно к своей таблице данных и таблице 
данных внешнего запроса и его результаты используются для 
выполнения внешнего запроса. 

В качестве примера для иллюстрации вложенного запроса, 
в котором внутренний запрос возвращает одно значение, 
рассмотрим таблицу Ргосіапо с колонками Оеіаі (наименование 
проданной детали), йаіа (дата продажи), Іпсірокир (индекс 
покупателя) и таблицу Коти с колонками РокираіеІ (наименова¬ 
ние организации - покупателя) и Іпсірокир (индекс покупателя). 
Для вывода наименования деталей и даты их продажи заводу 
"Уралмаш" можно выполнить запрос: 

8ЕІ.ЕСТ Оеіаі, йаіа 
РкОМ Ргосіапо 
ѴНЕкЕ Іпсірокир = 
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(5ЕІ.ЕСТ Іпсірокир 
РЙОМ Коши 

УНЕЙЕ Рокираіеі = "Уралмаш") 

ОЙЭЕЙ ВТ Оеіаі; 

Для возврата единственного значения из внутреннего 
запроса часто используются функции агрегирования: 

5Е1.ЕСТ Раш, Окіасі 
РЙОМ Касігу 
УНЕЙЕ Окіасі > 

(5ЕІ-ЕСТ АѴѲ(ОкІасІ) 

РЙОМ Касігу) 

ОЙЭЕЙ ВУ Раш; 

В последнем примере из таблицы Касігу (персональный 
учет кадров) с колонками Рат (фамилия) и Окіасі (зарплата) 
выбираются работники, получающие зарплату выше средней. 

В предложении \ЛЖЕКЕ можно включать несколько внутрен¬ 
них запросов, объединенных логическими операторами АИй, ОН 
и ИОТ для построения сложных условий. 

Пример: 

$Е1_ЕСТ Оеѣаі , Оаіа 
РЙОМ Ргосіапо 
УНЕЙЕ Іпсірокир = 

(ЗЕЬЕСТ Іпсірокир 
РЙОМ Коши 

УНЕЙЕ РокираЪеІ = "Уралмаш") 

ОЙ 2аѵосіпотег = 

(5Е1ЕСТ 2аѵосіпотег 
РЙОМ РГО І2Ѵ0СІ 

УНЕЙЕ йагѵапіе = "Знамя труда") 

ОййЕЙ ВУ 0е*а1; 

В данном примере выводятся детали, проданные "Урал¬ 
машу" или произведенные заводом "Знамя труда". 

Если внутренний запрос возвращает не одну, а несколько 
строк, то в предложении >УНЕКЕ необходимо включать опции, 
позволяющие воспринять несколько значений, например, 
ключевые слова ІИ, АИѴ и АН. 

Пример: 

5ЕІ.ЕСТ Оеѣаі, Раѣа 
РЙОМ Ргосіапо 
УНЕЙЕ Іпсірокир ІН 
(ЗЕ1.ЕСТ Іпсірокир 
РЙОМ Коши 

УНЕЙЕ РосЫіпсі ІЛКЕ "7%") 

ОЙЭЕЙ ВУ йеіаі; 

В последнем примере внутренний запрос отбирает организа¬ 
ции-покупатели, у которых почтовый индекс (колонка РосМіпсІ) 
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начинается с 7, затем внешний запрос в соответствии с 
индексом отобранных организаций (колонка Іпсірокир) выводит 
купленные ими детали. Следует отметить, что во внутреннем 
запросе нельзя использовать предложения ОѴЮЕК ВУ и ІІНІОИ. 
Внутренние запросы могут содержать предложения СКОІІР ВѴ 
и НЛУІИС, но в этом случае нельзя их использовать повторно 
в целом запросе. 

Проиллюстрируем использование ключевых слов АИУ и АН. 
Пример: 

5ЕІ-ЕСТ Оеіаі , КоІІсН, Мезіо 

РКОМ Зкіасіу 

УНЕКЕ КоІісН < АИУ 

(5Е1.ЕСТ КоІісН 

РКОМ Зкіасіу 

УНЕКЕ Мезіо = "Минск”) 

ОКОЕК ВУ Оеіаі; 

В приведенном примере выводятся наименования деталей 
(колонка ЭеІаІ) и их количество (колонка КоІісЬ) на тех 
складах (таблица Зкіасіу), на которых деталей меньше, чем на 
любом другом складе в Минске. 

Пример: 

5ЕІ.ЕСТ Эеіаі, КоІісН, Мезі;о 

РКОМ Зкіасіу 

УНЕКЕ КоІісН > АН 

(5Е1.ЕСТ КоІісН 

РКОМ Зкіасіу 

УНЕКЕ Мезіо = #, Киев м ) 

ОКОЕК ВУ Оеіаі; 

В данном примере выводятся наименования деталей и их 
количество на тех складах, на которых деталей больше, чем на 
других складах в Киеве. 

До сих пор рассматривались вложенные запросы с двумя 
уровнями вложенности. В принципе можно создавать запросы 
с неограниченным количеством уровней. 

Пример: 

5ЕІ.ЕСТ Іпсіогд, Огдапіг 
РКОМ Коти 
УНЕКЕ Іпсіогд ІИ 
(5ЕІ.ЕСТ Іпсіогд 
РКОМ Ргосіапо 
УНЕКЕ Иотгакаг ІИ 
(5Е1ЕСТ Иотгакаг 
РКОН Іакаг 

УНЕКЕ йеіпотег = ”005679")) 

0К0ЕК ВУ Огдапіг; 
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В последнем примере показан вложенный трехуровневый 
запрос, с помощью которого выводятся организации, которые 
купили (таблица Коти) детали с заданным индексом. Запрос 
нижнего уровня возвращает из таблицы 2акаг номера заказов 
(колонка Ыотгакаг), в которые входят детали с номером 
005679. Запрос следующего вверх уровня возвращает из 
таблицы Ргосіапо индексы организаций, в заказы которых 
(колонка Ыотгакаг) входили детали с номером 005679. И, 
наконец, запрос самого верхнего уровня возвращает из таблицы 
Коти наименования (колонка Огдапіг) и индексы организаций 
(колонка Іпсіогд), купивших детали с номером 005679. 

Этот же запрос можно записать в виде одноуровневой 
структуры, используя поиск по нескольким таблицам со 
сложным условием, заданным в предложении УЖЕКЕ: 

5ЕІ.ЕСТ Іпсіогд, Огдапіг 
ГРОМ Коти, Ргосіапо, 2акаг 
ѴНЕРЕ Іпсіогд = Ргосіапо. Иотгакаг 

А№ 2акаг.Иотгакаг = 2акаг.ОеЪпотег 
А№ 2акаг. йеіпотег = "005679 м 
ОРОЕР ВУ Огдапіг; 

Вообще любые вложенные запросы можно представить в 
виде одноуровнего запроса по нескольким таблицам (обратное 
не верно: не все одноуровневые запросы по нескольким 
таблицам можно представить в виде вложенных структур). Эти 
формы эквивалентны по своему результату, и пользователи 
могут выбирать ту структуру, которая кажется им нагляднее для 
записи запроса. 

В предложении УЖЕКЕ может использоваться предикат 
ЕХІ5Т5, позволяющий сформировать условие, которое оценивает 
результат выполнения вложенного запроса в целом, в отличие 
от оценки отдельных значений, возвращаемых внутренним 
запросом. Этот предикат возвращает логические значения 
"Истина" или "Ложь" в зависимости от того, возвращает или 
нет внутренний запрос какое-либо значение. Предикат ИОТ 
ЕХІ5Т5 возвращает соответственно инвертированные (обратные) 
логические значения. 

Пример: 

5ЕІ.ЕСТ Іпсіогд, Огдапіг, Мезіо 
ГРОМ Коти 
ѴНЕРЕ Ехізѣз 
(5ЕІ-ЕСТ * 

ГРОМ Ргосіапо 

ѴНЕРЕ Коти. Іпсіогд = Ргосіапо. Іпсіогд) 

0Р0ЕР ВУ Огдапіг; 

6 этом примере из таблицы Коти выводятся те организа¬ 
ции, которым что-либо продано, определяемое условием в 
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предложении ѴЖЕКЕ. Можно, наоборот, вывести организации, 
которым ничего не продано, используя вместо предиката ЕХІ$Т$ 
предикат ИОТ ЕХІ5Т5. 

Предикаты ЕХІ$Т$. и ИОТ ЕХІ$Т$ можно использовать 
многократно в многоуровневых вложенных запросах. Следует 
отметить, что только для этих предикатов во вложенных 
запросах разрешается в предложении 5ЕІ.ЕСТ использовать знак 
вывода всех колонок *. 

Наиболее сложной формой вложенных запросов является 
коррелированный запрос. В этом типе запроса данные из 
таблицы внешнего запроса используются при выполнении 
внутреннего запроса. 

Если во внутреннем и внешнем запросах используется одна 
и та же таблица, то необходимо задавать алиас (псевдоним) 
таблицы, так как формально могут сравниваться только различ¬ 
ные таблицы. 

Пример: 

5Е1.ЕСТ Раш, Оѣсіеі 
РВОМ Касігу 
У НЕ К Е Окіасі = 

(5ЕІ.ЕСТ МАХ(ОкІасі) 

РкОМ Касігу Зупопіт 

Ѵ/НЕКЕ Зупопіт. ОЪсІеІ = Касігу.Оѣсіеі) 

ОКйЕК ВУ Раш; 

В приведенном примере во внутреннем запросе использу¬ 
ется таблица из внешнего запроса, являющаяся одной и той же 
таблицей персонального учета кадров. Во внутреннем запросе 
определяется максимальный оклад сотрудников в отделах. Во 
внешнем запросе выполняется сравнение окладов сотрудников 
каждого отдела с максимальным окладом в соответствующем 
отделе. Если оклад равен максимальному, то эта строка 
выводится в результирующую таблицу. 

В следующем примере из таблицы Ргосіапо выводятся все 
индексы организаций (колонка Іпсірокир), сделавших более 
одного заказа (колонка Ыотгакаг). 

Пример: 

ЗЕ1.ЕСТ Іпсірокир, Иотгакаі 

ГНОМ Ргосіапо 

Ѵ/НЕКЕ Іпсірокир ІИ 

(ЗЕІ.ЕСТ Зупргосі. Іпсірокир 

ГРОМ Ргосіапо Зупргосі 

Ѵ/НЕКЕ Иотгакаг <> Зупргосі.Иотгакаг) 

ОКОЕК ВУ Іпсірокир, Иотгакаг; 
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4.7. СОВМЕСТНОЕ ИСПОЛЬЗОВАНИЕ КОМАНД ЗОЬ И сІВАЗЕ 

Как уже указывалось, в СУБД СІВА5Е IV можно совместно 
использовать команды 501. и команды и функции языка 
сІВАЗЕ IV с целью выполнения различных операций при работе 
с БД. Пользуясь только командами 5СН_, можно создавать и 
удалять таблицы данных и их индексы, вводить, обновлять, 
удалять или отбирать данные. Кроме того, можно устанавливать 
привилегии для доступа к данным. Функции агрегирования 
501. позволяют выполнять простые статистические операции 

($іж{), соіжто, аѵсо, мшо и махо). 

Язык сІВАЗЕ IV можно применять в командном режиме для 
создания и распечатки отчетов с данными, отобранными 
запросами на языке 50І_. 

Команды и функции языка сІВАЗЕ IV можно также исполь¬ 
зовать для преобразования или форматирования данных, 
полученных по запросам на языке $ОІ_, установки параметров 
и состояний среды и разработки основной части прикладных 
программ. 

Напомним, что для выполнения команд ЗОЕ и сІВАЗЕ IV 
предусмотрены раздельные режимы из-за различия систем 
доступа к данным. При наборе и выполнении команд с 
клавиатуры можно переходить из одного режима в другой, 
выполняя команды 501- или сІВАЗЕ IV по обработке одних и 
тех же данных. При этом язык ЗОІ_ целесообразно использовать 
для отбора данных, а язык сІВАЗЕ для организации форматиро¬ 
ванного ввода и вывода. 


Команды языка сІВАЗЕ IV, разрешенные в режиме 301. 


?, ?? или ??? 

&& 

* 

@...СІ_ЕАК 

@...ООиВ1Е/РАЫЕ1/ЫОМЕ... 

то... 

@...5АѴ...ОЕТ 

АССЕРТ 

АСТІѴАТЕ МЕЫІІ 
АСТІѴАТЕ РОРІІР 
АСТІѴАТЕ 5СРЕЕЫ 
АСТІѴАТЕ Ѵ/ІЫООѴ/ 
ВЕОт...ЕЫО ТКАИЗАСТІОЫ 
САІ_І_ 

САІЧСЕ1- 
СІ.ЕАК ОЕТ5 


СІ.ЕАК МЕІЧУ5 
СІ.ЕАК РОРІІР5 
СІ.ЕАК ТѴРЕАНЕАй 
СІ.ЕАР ѴѴІЫООѴ/5 
СЮ5Е АІ.ТЕКІЧАТЕ 
СЮ5Е РОКМАТ 
СЮ5Е РРОСЕОШЕ 
СОМРИЕ 
СОРУ РІІ.Е 
ОЕАСТІ ѴАТЕ МЕЫІІ 
ОЕАСТІѴАТЕ РОРІІР 
ОЕАСТІ ѴАТЕ ѴУІЫООѴУ 
ОЕВІІС 
ОЕСІ.АКЕ 
ЭЕРІМЕ ВАК 
ОЕРІЫЕ ВОХ 
РЕРІЫЕ МЕИУ 
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ОЕРІЫЕ РАО 
ЭЕРІЫЕ РОРЫР 
ОЕРІЫЕ Ѵ/ІЫООѴ/ 

ЭЕІ.ЕТЕ РНЕ 
ОI Р/О IРЕСТ ОРУ 
ОІ5РІАѴ РІІ.Е5 
ЭІ5РІ.АѴ НІ5ТОРѴ 
ЭІЗРІ-АѴ МЕМОРѴ 
ОІ5РІ.АѴ 5ТАТІІ5 
ЭІЗРІ-АѴ ІІ5ЕР5 

оо 

ОО САЗЕ...САЗЕ 

ОТНЕРѴѴІ5Е...ЕЫОСА5Е 
ОО Ѵ/ННЕ...ЕЫООО 
Е^СТ 
ЕРА5Е 
ЕХІТ 

РІІЫСТІОЫ 

НЕІ.Р 

ІР...Е15Е...ЕЫОІР 

ІЫРІЛ 

ИІБТ РІІ.Е5 

и$т нізторѵ 

Ы5Т МЕМОРѴ 
Ы5Т 5ТАТІІ5 
Ы$Т ІІ5ЕР5 
ЮАЭ 

юѳоііт 

ЮОР 

МООІРѴ СОММАЫО/РПЕ 
МОѴЕ ОЕТ5 
МОѴЕ Ѵ/ІКЮОѴѴ 
ЫОТЕ 

ОЫ ЕРРОР/Е5САРЕ/КЕѴ 

ОЫ РАО 

ОЫ РАСЕ 

ОЫ РЕАЭЕРРОР 

ОЫ 5ЕІ.ЕСТІОЫ РАО 

ОЫ 5ЕІ.ЕСТЮЫ РОРІІР 

РАРАМЕТЕР5 

РІ.АѴ МАСРО 

РРІЫТЮВ...ЕЫЭРРІЫТ 

РРІѴАТЕ 

РРОСЕОІІРЕ 

РРОТЕСТ 

РІІВІ.ІС 

оілт 


РЕАР [ЗАѴЕ] 

РЕІ.ЕА5Е 

РЕІ.ЕА5Е МЕЫІІ5 
РЕІ.ЕА5Е МОЭІЛ-Е 
РЕІ.ЕА5Е РОРОРЗ 
РЕІ.ЕА5Е ѴѴІЫООѴ/5 
РЕЫАМЕ 
РЕ5ТОРЕ РРОМ 
РЕ5ТОРЕ МАСРОЗ 
РЕ5ТОРЕ МЕЫІІ 
РЕ5ТОРЕ Ѵ/ІЫООѴ/ 

РЕ51ШЕ 

РЕТРѴ 

ретііры 

РІЛЧ 

ЗАѴЕ МАСРОЗ 
ЗАѴЕ ТО 
ЗАѴЕ Ѵ/ІЫООѴ/ 

ЗЕТ 

ЗЕТ АІ.ТЕРЫАТЕ ОЫ/ОРР 

ЗЕТ АІІТОЗАѴЕ ОЫ/ОРР 

ЗЕТ ВЕН ТО 

ЗЕТ ВЕН ОЫ/ОРР 

ЗЕТ ВОРОЕР 

ЗЕТ СЕЫТІІРѴ ОЫ/ОРР 

ЗЕТ СЮСК ОЫ/ОРР 

ЗЕТ СЮСК ТО 

ЗЕТ СОЮР ОР 

ЗЕТ СОЮР ОЫ/ОРР 

ЗЕТ СОЮР ТО 

ЗЕТ СОЫРІРМ ОЫ/ОРР 

ЗЕТ СОЫЗОІ-Е ОЫ/ОРР 

ЗЕТ СІІРРЕЫСѴ І.ЕРТ/РІСНТ 

ЗЕТ ССІРРЕЫСѴ ТО 

ЗЕТ ОАТЕ 

ЗЕТ ОЕВІІС ОЫ/ОРР 

ЗЕТ ОЕСІМАЬЗ ТО 

ЗЕТ ОЕРАІЛТ ТО 

ЗЕТ ЭЕІ.ЕТЕО ОЫ/ОРР 

ЗЕТ ЭЕЫМІТЕРЗ ОЫ/ОРР 

ЗЕТ РЕЫМІТЕРЗ ТО 

ЗЕТ ЭЕѴЕЮРМЕЫТ ОЫ/ОРР 

ЗЕТ ОЕѴІСЕ ТО 

ЗЕТ ЭІЗРІ-АѴ ТО 

ЗЕТ ЭОНІЗТОРѴ ОЫ/ОРР 

ЗЕТ ЕСНО ОЫ/ОРР 

ЗЕТ ЕЫСРѴРТІОЫ ОЫ/ОРР 
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ЗЕТ Е5САРЕ ОЫ/ОРР 


ЗЕТ 

РКІЫТЕК ОЫ/ОРР 

5ЕТ ЕХАСТ ОЫ/ОРР 


ЗЕТ 

РКІЫТЕК ТО 

5ЕТ ЕХСШ5ІѴЕ ОЫ/ОРР 

ЗЕТ 

РКОСЕОІІКЕ ТО 

5ЕТ РІХЕЭ ОЫ/ОРР 


ЗЕТ 

КЕРКЕЗН ТО 

ЗЕТ РОКМАТ ТО 


ЗЕТ 

КЕРКОСЕ55 ТО 

ЗЕТ РУЫСТЮЫ 


ЗЕТ 

5АРЕТѴ ОЫ/ОРР 

ЗЕТ НЕАЭІЫО ОЫ/ОРР 

ЗЕТ 

ЗСОКЕВОАКй ОЫ/ОРР 

ЗЕТ НЕІ.Р ОЫ/ОРР 


ЗЕТ 

5ЕРАКАТОК ТО 

ЗЕТ НІ5ТОКУ ОЫ/ОРР 


ЗЕТ 

5РАСЕ ОЫ/ОРР 

ЗЕТ НІ5ТОКУ ТО 


ЗЕТ 

501. ОЫ/ОРР 

зет ноикз то 


ЗЕТ 

5ТАТІІ5 ОЫ/ОРР 

ЗЕТ ІЫТЕЫ5ІТѴ 


ЗЕТ 

5ТЕР ОЫ/ОРР 

ЗЕТ ЮСК ОЫ/ОРР 


ЗЕТ 

ТАІ.К ОЫ/ОРР 

ЗЕТ МАКСІЫ ТО 


ЗЕТ 

ТКАР ОЫ/ОРР 

ЗЕТ МАКК ТО 


ЗЕТ 

ТУРЕАНЕАЭ ТО 

ЗЕТ МЕЫІІ5 ОЫ/ОРР 


5НОѴ/ МЕЫЧ 

ЗЕТ МЕ55АОЕ ТО 


5НОѴ/ РОРУР 

ЗЕТ ОООМЕТЕК ТО 


5ТОКЕ 

ЗЕТ РАТН ТО 


51І5РЕЫО 

ЗЕТ РАІІ5Е ОЫ/ОРР 


ТЕХТ...ЕЫОТЕХТ 

ЗЕТ РОІЫТ ТО 


ТѴРЕ 

ЗЕТ РКЕСІ5ІОЫ ТО 


ѴУАІТ 

Функции с!ВА$Е ІѴ Г разрешенные в режиме $СЫ 

&" 

ОМѴ() 


ЬАЗТКЕУО” 

АВ5() 

ООѴѴ() 


ІЕРТ() 

АС05() 

ОТОС() 


ЬЕЫ() 

А5С() 

ртоко 


ЬІКЕО* 

А5ІЫ() 

этозо 


иыЕыоо* 

АТ () 

ЕККОКО' 


ЮО() 

АТАЫ() 

ЕХР 


юоіоо 

АТЫ2() 

РНЕО* 


ЬОѴѴЕКО 

ВАК()“ 

РІХЕЭО 


ілкімо 

САЩ)* 

РКІ.АВЕЦ)' 


МАХ()" 

СООѴ/() 

РКМАХО* 


МОУ() 

СЕІЫЫОО 

РЮАТ() 


МЕМОКУО* 

СНК() 

РЮОК() 


мЕыио* 

смоытно 

ОЕТЕЫѴ()" 


МЕ55АОЕ()“ 

СОЦ)' 

ІРР()- 


МІЫ()’ 

СОМРЬЕТЕОО" 

ІЫКЕѴ()* 


МОйЕ() 

СОЗ() 

ІЫТ() 


МОЫТНО 

ЭАТЕО 

І5АІ.РНА0* 


ЫЕТѴѴОККО* 

ОАѴ() 

ІЗСОЮКО' 


050* 

ЭІРРЕКЕЫСЕО 

І5ЮѴѴЕК0' 


РАйО* 

ОІ5К5РАСЕ()“ 

ІЗУРРЕКО* 


РСОЦ)* 
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РІ() 

коѵѵо* 

$іім() 

рор^О' 

ртооо 

ТАЫ() 

ркіытзтАтизо* 

рткімо 

ТІМЕО 

РКООРАМО' 

5ЕТ()“ 

ТКАЫЗРОКМО 

ркомрто* 

51<ЗЫ() 

ткімо 

ркоѵѵ()- 

5ІН() 

ТУРЕ()* 

КАЫО() 

$оиыоЕХ() 

іірреко 

КЕАОКЕѴО* 

$РАСЕ() 

ІІ$ЕР() 

КЕРЫСАТЕО 

$ОКТ() 

ѴАЦ) 

к і онто 

$ТК() 

ѴАРКЕАОО* 

КОИВАСКО' 

зтіірро 

ѴЕК5ІОЫ0* 

коііыоо 

5УВ5ТК0 

ѴЕАК() 


Символом * отмечены функции, которые разрешены в 
режиме ЗОІ-, но не разрешены в командах 5СН-. 

Команды и функции, которые открывают файлы БД (Ц$Е), 
устанавливают указатель записи (КЕСНО(), СОТО и 5КІР) и 
осуществляют поиск и вывод данных (РІИО, 5ЕЕК и йІЗРІ-АѴ) 
нельзя использовать в режиме 5СН-. Эти действия должны 
выполняться командами 50І_. 

В режиме 501. команды сІВАЗЕ IV набираются как обычно 
и в отличие от команд 501- не завершаются точкой с запятой. 
Выполнение осуществляется нажатием клавиши Епіег. Например, 
для изменения формата даты набирается команда $ЕТ йАТЕ ТО 
СЕКМАЫ. 

Функции, перечисленные выше, могут использоваться 
в режиме ЗСН. в командах как сІВАЗЕ IV, так и 5СН- 
(не отмеченные знаком *). 

Выше в примерах приводилось использование функций 
сІВАЗЕ в предложениях ЗЕ1.ЕСТ и \УНЕВЕ при формировании 
запросов. Приведем еще пример выполнения команды ЗОЬ с 
функциями сІВАЗЕ при наборе их с клавиатуры. Например, 
требуется извлечь из таблицы Касігу фамилию и инициалы 
(колонки Рат и Іпіі) лиц, принятых на работу до июня месяца 
текущего года (колонка даты приема Ьаіаі): 

ЗЕІ.ЕСТ КШМ(Раш) + $РАСЕ(1) + ІпП, ЭаШ 

РВОМ Касігу 

ѴНЕКЕ УЕАКЮаѣаІ ) = 89 А№ МСЖТН(0а*а1) < 6; 

В языке ЗСН. пакета сІВАЗЕ IV предусмотрена команда для 
сохранения на диске результатов выполнения запроса: 

5АѴЕ ТО ТЕМР <имя таблицы > [(список колонок)][КЕЕР]; 

где <имя таблицы > - имя таблицы, в которой сохраняются 
результаты выполнения запроса; (список колонок) - список 
имен выводимых колонок. 
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Опция КЕЕР позволяет сохранить таблицу в виде файла БД 
сІВАЗЕ IV (с расширением .с ІЫ). 

Эта команда полезна при разбивке сложных команд ЗЕІ.ЕСТ 
на небольшие, более простые операции. Разделяя такие 
операции, как вложенный запрос или запрос на извлечение 
данных из нескольких таблиц на части, можно выполнять их по 
этапам, проверяя результаты выполнения промежуточных 
операций. 

Другое применение этой команды заключается в преобразо¬ 
вании результирующей таблицы в файл БД сІВАЗЕ IV (при 
использовании опции КЕЕР). Затем этот файл можно использо¬ 
вать для вывода отчетов или марок, разработанных в УЦ 
сІВАЗЕ IV, или продолжить обработку данных с помощью 
команд сІВАЗЕ IV. 

Если опция КЕЕР не задана, то результирующая таблица 
сохраняется временно, до тех пор, пока остается активным 
текущий файл БД, в течение текущего сеанса режима 301. или 
в течение выполнения процедуры высшего уровня, вызвавшей 
программный файл .рг$. Можно также создать файл выборки с 
помощью команды СВЕАТЕ ѴІЕ>Ѵ, используя команду ЗЕ1.ЕСТ 
для определения строк и столбцов выборки. В случае задания 
опции КЕЕР для создания файла БД, можно на основе этого 
файла, используя команду ОЕЮЕРІ№, создать таблицу ЗСЛ.. 

Пример: 

8ЕІ.ЕСТ 015ТIИСТ Иотгакаг, 2акаг. Иоілсіеі: , Орізапіе, 

КоІІсН, 8*о1тес1, (Коі 1сН*81оітесі) 

РЙОМ 2акаг, 8к1асІ 

ѴНЕКЕ ЗкІагі.Иотгіеі = Іакаг.Иотсіеі: 

ОКОЕЯ ВУ 2акаг.Нотіакаг 

8АѴЕ ТО ТЕМР ИаПсМе (Лотгакаг, Мотсіеі, Орізапіе, 

КоІІсЬ, 8іо1тесІ, Ѵзедо); 

Этот запрос по двум таблицам 2ак аі (заказы на покупку 
деталей) и ЗкІасІ (наличие деталей на складе) возвращает 
таблицу, сохраняемую временно под именем ЫаІісЫе, в которой 
перечисляются заказанные детали, имеющиеся на складе. Все 
колонки этой таблицы те же самые, что и в результирующей 
таблице, заданной предложением ЗЕ1.ЕСТ, за исключением 
вычисляемой колонки, которая названа Ѵзедо. Для проверки 
правильности выполнения запроса можно выполнить команду 

8ЕІ.ЕСТ * 

ГРОМ ИаИсЫе; 

Для формирования таблицы данных, необходимых при 
выписке накладных на покупку деталей, выполняются следующие 
команды: 

8ЕІ.ЕСТ 0І8ТІИСТ Раш, Оа*а, Иа 11сМе.Ношгакаі, Иотсіеі, 

Орізапіе, КоІІсН, 8іо1тегі, Ѵзедо 
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ГНОМ Рокираіеі, Ргойапо, ИаИсНіе 

«НЕКЕ Ргогіапо. Иотгакаг = Рокираіеі .Иошрокир 

АИй НаІІсНІе.Иотгакаг = Ргосіапо. Иотгакаг 

ОКРЕК ВУ Ргогіапо.Иотгакаг 

$АѴЕ ТО ТЕМР Иакіагі (Раш, Иотзкіасі, Иотгакаг, Иотсіеі, 

Орізапіе, КоІісН, $Іоітесі, Ѵзедо) КЕЕР ; 

Запрос, сформированный из приведенных команд, завершает 
операции по сбору всей необходимой информации для печати 
накладных. Результирующая таблица записывается в виде файла 
БД с именем ЫакІасІ. Для проверки формирования данных 
можно выполнить команду 

5ЕІ.ЕСТ * 

ГРОМ Мак 1 асі ; 

После этого остается создать форму (отчет) накладных и 
отпечатать их. Для этого можно использовать генератор отчетов 
УЦ сІВАЗЕ IV. 

Файлы БД и индексы сІВАЗЕ IV можно использовать в 
режиме 501., но предварительно требуется определить эти 
файлы как таблицы 5СН-. Для этого необходимо обновить 
каталоги таблиц ЗОЬ с помощью сервисной команды ОВОЕРІИЕ, 
чтобы включить в них информацию о файлах БД и связанных 
индексных файлах. После того как файл БД определен как 
таблица 501., его структуру уже нельзя модифицировать с 
помощью команд сІВАЗЕ IV. В режиме сІВАЗЕ можно использо¬ 
вать все команды сІВАЗЕ IV для доступа к таблицам ЗОІ_, так 
как они всегда записываются с расширением .сІЫ. Можно 
добавлять, обновлять или удалять данные в этих файлах БД, 
используя команды сІВАЗЕ IV со следующими ограничениями: 

1. Если установлена защита данных командой Р&ОТЕСТ, то 
нельзя в режиме сІВАЗЕ получить доступ к файлам БД, 
созданным в режиме 501- (можно использовать команды ЗЕТ 
ЕИСРѴРТІОИ и СОРУ для создания дешифрованных копий этих 
файлов). 

2. Нельзя использовать команды МОРКРѴ ЗТКІІСТІІКЕ и 
СОИѴЕРТ ТО для файлов БД, созданных в режиме ЗОЬ. 

3. При создании новых файлов БД нельзя использовать 
имена уже имеющихся файлов, созданных в режиме ЗСН-. 

4. Указатели связанного множественного индексного файла 
(имеющего то же имя, что и файл БД) нельзя удалять или 
добавлять, если файл БД определен как таблица ЗОЕ (с 
помощью команды СКЕАТЕ ТАВ1.Е ИЛИ ОВРЕРІИЕ). 

5. Не разрешается обновлять созданные в ЗОІ_ файлы БД, 
для которых в 501- установлен индекс с опцией ІЖІСШЕ (с 
помощью команды СНЕ АТЕ ІИйЕХ). Нельзя также обновлять 
каталоги таблиц 501.. 

Упоминавшаяся выше команда ОЕШЕРІЫЕ [<имя .сІЫ 
файла >]; позволяет определить файл БД сІВАЗЕ IV как таблицу 
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501_. Эта команда формирует и вводит необходимую информа¬ 
цию в каталог БД 501. для обеспечения входа в файл БД и 
связанные с ними множественные индексные файлы, созданные 
в режиме сІВАЗЕ, что позволяет осуществлять доступ к ним с 
помощью команд 501.. Команда вводит в каталог информацию 
об одном или в$ех файлах БД текущего директория. 

Для того, чтобы ввести все файлы БД текущего директория 
в состав новой БД 501., необходимо выполнить следующее: 

1. Создать БД 501., используя команду СКЕАТЕ ЬДТАВАЗЕ 
(если требуется добавить файлы БД в существующую БД 5СН., 
то этот пункт пропускается). 

2. Скопировать файлы БД, поля Мето и индексные файлы 
в директорий, в котором требуется их хранить (для этого 
можно использовать команду СОРУ РНЕ в режиме 501.). 

3. Активизировать БД, используя команду 5ТАКТ РАТАВАЗЕ. 

4. Выполнить команду ОВРЕРІЫЕ. Все файлы БД, скопиро¬ 
ванные в директорий, будут введены в таблицы каталога БД 
(для ввода конкретных файлов БД требуется указать их имена 
непосредственно в команде РВОЕРШЕ). 

Команда РВОЕРЖЕ определяет таблицы только для неза¬ 
шифрованных файлов БД. Для дешифрования зашифрованных в 
режиме сІВАЗЕ файлов перед выполнением команды ОВРЕРЖЕ 
следует выполнить команду ЗЕТ ЕЫСКѴРТЮН ОРР и затем 
скопировать их командой СОРУ ТО для создания незашифрован¬ 
ных копий файлов. 

При определении файлов БД как таблиц с помощью 
команды ОВОЕРШЕ нельзя включать в каталог 501. выборки 
файлов БД сІВАЗЕ IV. Для этого сначала надо включить в 
каталог файлы БД, представленные в выборке, а затем создать 
выборку 501., эквивалентную выборке сІВАЗЕ. Кроме того, 
нельзя включать в каталог индексные файлы с расширеним .псіх. 
Необходимо преобразовать эти файлы .псіх в указатели 
множественных индексных файлов .тсіх и затем выполнить 
команду РВРЕРЖЕ. 

После обновления каталога 501. команда РВРЕРЖЕ записы¬ 
вает текстовый файл РЬсІеІіпе.Ш в директорий текущей БД. 
Этот файл содержит информацию о всех файлах БД, опреде¬ 
ленных как таблицы 501., а также о файлах БД, для которых 
операция определения как таблиц 501. завершилась неуспешно. 

Если при выполнении команды ОВРЕРЖЕ включаются файлы 
.тсіх, то в каталог вводятся данные о последней выполненной 
команде КЕЖйЕХ. Необходимо выполнять эту команду перед 
установкой режима 501., иначе данные о переупорядочивании 
индексного файла не будут внесены в каталог. В режиме 501. 
эту операцию следует выполнять командой К1Ж5ТАТ5. 

Выполнение команды РВРЕРЖЕ можно показать на следую¬ 
щем примере. Пусть требуется в командном режиме опреде¬ 
лить как таблицу 501. файл БД Касігу в текущей БД 501.: 
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&ВОЕРІИЕ Касігу ; 

Дл$ просмотра информации в таблице каталога 501- следует 
выполнить команду 

5Е1.ЕСТ * 

РКОМ ЗузЪаЫз; 

В таблице ЗузіаЫз каждая строка содержит данные об 
одной таблице 501- в текущей БД. Для просмотра информации 
о колонках, которая введена в каталог, следует выполнить 
команду 

5Е1.ЕСТ Соіпо, Соіпате, СоНуре, Соііеп 

РКОМ Зузсо18 

Ѵ/НЕКЕ ТЬпате = "КасІгу"; 

Выводимая этой командой информация позволяет убедиться 
в том, что в каталог введена та же структура файла БД, 
которая определена в сІВАЗЕ. 

Для проверки введенной информации о файлах БД и 
связанных с ними множественных индексных файлах в каталоги 
501- при определении файлов БД в виде таблиц 501. использу¬ 
ется команда 

йВСНЕСК [симя таблицы >]; 

Проверка осуществляется посредством сравнения данных в 
таблицах каталога ЗОЕ с действительной структурой файлов БД 
в текущем директории. Если нет совпадения, то выводится 
сообщение об ошибке. В этом случае необходимо выполнить 
следующее: 

скопировать файлы БД и индексы .тсіх, перечисленные в 
сообщении об ошибке в другой директорий; 

уничтожить эти таблицы из БД 501- командой ОКОР; 

скопировать файлы БД и индексы .тсіх обратно в директо¬ 
рий БД; 

выполнить команду ОВйЕЕІИЕ симя файла БД> для 
переопределения файлов БД как таблиц 501-. 

В режиме 501- имеется две команды І.ОАР РАТА и 
ІІИІ-ОАЬ РАТА, которые позволяют передавать данные между 
БД 501. и внешними файлами данных. Можно передавать те же 
типы файлов, что и командами АРРЕИР ЕРОМ и СОРУ ТО из 
режима сІВАЗЕ: 

сІВАЗЕ II, сІВАЗЕ III, сІВАЗЕ N1+ и сІВАЗЕ IV; 

КарісІРіІе (КРО); 

Ргатеѵѵогк 11 - файлы БД и электронные таблицы (РѴУ2); 

Файлы А5СІІ с разделителями (ОЕЫМІТЕО); 

Файлы А5СІІ системного формата данных (5РР); 

ѴізіСаІс (ЭІР); 

МиЖрІап - электронные таблицы - (5ѴІ-К); 

ЬоЖз 1-2-3 (Ѵ/К5). 
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Команды ЮАО и ЦИЮЛО могут выполняться как в режиме 
набора с клавиатуры, так и в программах. Данные импортиру¬ 
ются или экспортируются из таблиц 501. в текущую БД. 
Внешние файлы могут быть в текущем или другом директории. 
В последнем случае, как обычно, следует перед именем файла 
указать имя диска и маршрут по директориям. 

Для добавления данных из внешнего файла в конец 
существующей таблицы $01. в текущей БД используется команда 

ІО АО РАТА РВОМ [путь] < имя файла > 

ІЫТО ТАВІ.Е <имя таблицы > 

[[ТѴРЕ]$ОРД> I Р/^К$/$Ѵ 1.К/Р^2/ВР0/0В А$Е 11/ 
ОЕЫМІТЕО [^ІТН ВІ.АНК/Ѵ/ІТН <разделитель>]]; 

Если не задан тип файла, то предполагается файл сІВАЗЕ 
(кроме сІВАЗЕ II). Для файлов сІВАЗЕ импортируются данные 
только тех полей, которые определены как колонки в заданной 
таблице 301. (поля Мето не копируются). 

При импорте из электронных таблиц или файлов с раздели¬ 
телями структура таблицы ЗСН., в которую загружаются данные, 
должна соответствовать формату файла, из которого осуществля¬ 
ется импорт. Определения колонок таблицы должны соответ¬ 
ствовать длине и типу данных импортируемого файла. Если в 
импортируемом файле поля шире колонок таблицы, то происхо¬ 
дит усечение не поместившихся данных. Строки электронной 
таблицы помещаются в строки таблицы $ОІ_. 

Копирование данных из таблиц ЗСН. во внешние типы 
файлов осуществляется командой 

ЦИІОАО О АТ А РВОМ [путь по директориям] < имя файла > 
РВОМ ТАВІ.Е <имя таблицы > 

[[ТѴРЕ]$0Р/0 1 Р/Ѵ^К$/$ѴІ_К/РѴ^2/ВРО/ОВА5Е 11/ 
ОЕЫМІТЕО [^ІТН ВІ.АНК/Ѵ/ІТН < разделитель >]]; 

Здесь, так же как и для команды І.ОАО, не требуется 
указывать тип файла для файлов сІВАЗЕ, кроме сІВАЗЕ II. В 
экспортируемом файле создаются поля (колонки электронной 
таблицы) в соответствии со структурой таблицы ЗСН.. 

Если таблица защищена командой РВОТЕСТ, то необходимо 
иметь привилегию ЗЕІ.ЕСТ, чтобы выполнить команду ІЖІ.ОАО. 
При этом файл автоматически дешифруется. 


4.8 ЗАЩИТА ИНФОРМАЦИИ И РАБОТА В СРЕДЕ ЛВС 

Информация в сІВАЗЕ IV защищается как в режиме сІВАЗЕ, 
так и в режиме $ОІ_. Система защиты организуется и устанавли¬ 
вается администратором системы с использованием команды 
сІВАЗЕ IV РВОТЕСТ. После назначения паролей и ввода данных 
по защите информации пользователи входят в систему по 
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индивидуальным паролям и выполняют те операции с данными, 
которые определены установленными привилегиями. В режиме 
сІВАЗЕ IV привилегии по работе с файлами назначаются при 
выполнении команды РКОТЕСТ. В режиме 501- привилегии 
назначаются командами СКАИТ и КЕѴОКЕ. После ввода данных 
по защите информации с помощью команды РКОТЕСТ доступ 
к файлам БД, определенным как таблицы ЗСН., осуществляется 
только командами 501.. Информация о пользователях, которые 
работают с таблицами ЗОЕ, введенная с помощью команды 
РКОТЕСТ, хранится в файле ОЬ$у$іет.^І в том же директории, 
что и аналогичный файл 0Ь$у$1ет.сІЬ при операциях с файлами 
БД в режиме сІВАЗЕ. 

Перед выполнением команд СКАИТ и КЕѴОКЕ в режиме 
ЗОЬ необходимо с помощью команды РВОТЕСТ ввести имена 
групп пользователей, их идентификаторы и пароли. Одному из 
пользователей может присваивается системный идентифи¬ 
катор - ЗОЮВА. Пользователь с этим идентификатором имеет 
привилегии администратора системы по выполнению любых 
операций 501- с любыми таблицами и выборками. Полный 
объем привилегий над созданными таблицами имеют их авторы. 
Они могут делегировать и ограничивать привилегии другим 
пользователям по работе со своими таблицами (пользователь 
с идентификатором ЗОЮВА имеет такие права по всем 
таблицам). Все привилегии, назначенные командами СКАИТ и 
ВЕѴОКЕ, записываются в таблицы каталога для активной БД. 

Как и в режиме сІВАЗЕ IV, в режиме 501- предусмотрено 
шифрование данных. Защищенные таблицы шифруются сразу 
после их создания. Данные в таблицах, созданных в режиме 
501., недоступны в режиме сІВАЗЕ. Для обеспечения доступа к 
ним в режиме сІВАЗЕ необходимо скопировать их из таблицы 
в файл БД командой ІІИІ.ОАО или использовать предложение 
ЗАѴЕ ТО ТЕМР в команде ЗЕЬЕСТ. 

Подобно этому нельзя выполнять команды ОВРЕРІИЕ или 
МАО для зашифрованных в режиме сІВАЗЕ файлов БД. Перед 
выполнением этих команд надо предварительно установить 
состояние (выполнить команду) ЗЕТ ЕИСКѴРТІОИ ОРР и 
скопировать с помощью команды СОРУ РІІ.Е файлы, которые 
при копировании дешифруются. Для создания дешифрованной 
копии зашифрованного в режиме сІВАЗЕ файла пользователю 
необходимо иметь привилегию по чтению этого файла. 

Для назначения привилегий пользователям по работе с 
таблицами и выборками используется команда 

СКАИТ АН [РКІѴИЕСЕ5]/<список привилегий> 

ОН [ТАВІ.Е] < список таблиц > 

ТО РУВЫС/с список пользователей> 

[Ѵ/ІТН СКАИТ ОРТІОН]; 
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Эта команда позволяет назначить привилегии, которые 
соответствуют операциям над таблицами, выполняемыми 
командами АНЕК, СВЕАТЕ, 1№ЕХ, 0Е1.ЕТЕ, 1№ЕВТ, 5ЕІ.ЕСТ и 
ІІРРАТЕ. Дополнительно назначаемые привилегии не отменяют 
имевшиеся, т.е. привилегии накапливаются при повторном 
выполнении команды СКАИТ. 

Пользователю можно назначить привилегию делегировать 
все или часть своих привилегий другим пользователям (опция 
^ІТН СКАМТ ОРИОН). Если привилегии пользователя аннулиру¬ 
ются, то соответственно аннулируются привилегии, делегирован¬ 
ные этим пользователем другим пользователям. 

Команда СВАЫТ позволяет назначить все привилегии с 
помощью опции АН. или отдельные привилегии в виде 
соответствующих ключевых слов: 

АПЕР - возможность добавлять колонки в таблицу; 

0Е1.ЕТЕ - возможность удалять строки из таблицы или 

выборки; 

ІЫРЕХ - возможность использовать команду СВЕАТЕ ІЫРЕХ; 

ІИ5ЕВТ - возможность добавлять строки в таблицу или 

выборку; 

5ЕІ.ЕСТ - возможность выводить строки из таблицы или 

выборки; 

ІІРРАТЕ [(список колонок)] - возможность обновлять все 
или заданные колонки в таблице. 

В команде СВАЫТ можно назначить заданные привилегии 
всем пользователям (опция ТО РІІВИС) или пользователям, 
указанным в списке пользователей (список идентификаторов 
пользователей, введенных командой РВОТЕСТ). 

Примеры: 

бКАИТ АН. ОИ ТАВІ.Е Касігу ТО Іѵапоѵ; 

6КАИТ ІИ5ЕКТ, ІІРОАТЕ , 0Е1_ЕТЕ ОИ Ріап ТО РОВНО 

В первом примере предоставляются все привилегии для 
операций над таблицей Касігу пользователю с идентификатором 
Іѵапоѵ. Во втором примере предоставляются всем пользовате¬ 
лям привилегии ІІЧ5ЕВТ, ЦІРРАТЕ и ЭЕЬЕТЕ для работы с 
таблицей Ріап. 

Аннулирование привилегий пользователям по работе с 
таблицами и выборками выполняется командой 

КЕѴОКЕ АН [РКІѴИЕСЕ5]/ <список привилегий> 

ОИ [ТАВІ.Е] < список таблиц > 

РВОМ РІІВНС/<список пользователей>; 

Можно аннулировать все привилегии для указанных 
пользователей с помощью опции ап или указать конкретные 
привилегии в виде ключевых слов, отделенных запятыми. 
Ключевые слова те же, что и в команде СКАИТ. 


318 



Пример: 

КЕѴОКЕ ІІРОАТЕ г ІЫ5ЕЙТ ОИ Ріап Ргош Ре*гоѵ; 

Команда КЕѴОКЕ с опцией РІЛИ.ІС аннулирует только 
привилегии, предоставленные ранее командой СКАИТ ТО 
РІРВЫС, так как пользователи могут дополнительно получать 
привилегии, назначенные им индивидуально. 

В режиме 5СМ_, как и в СІВА5Е IV, предусматривается три 
способа разрешения конфликтов, возникающих в ситуации 
одновременного обращения нескольких пользователей к одному 
файлу: установка файлов в режим обработки только одним 
пользователем, захват файлов в течение выполнения операции 
и захват отдельных записей. 

В ряде случаев, например в ходе многочисленных обновле¬ 
ний данных всего файла БД, требуется установить исключитель¬ 
ную прерогативу обработки этого файла одним пользователем, 
запретив обращение к нему других пользователей. В других 
случаях, например при выполнении небольшого объема обновле¬ 
ний, можно открыть доступ многих пользователей к файлу. 

В режиме 5С2І-, как и в СІВА5Е IV, захват записей и файлов 
осуществляется автоматически. При выполнении команд $ОІ_ по 
вводу, обновлению и удалению данных в таблице или выборке 
501- автоматически определяется необходимый вид захвата. Если 
невозможно завершить операцию захвата ввиду того, что 
информация захвачена другим пользователем, продолжается 
попытка захвата в течение заданного периода времени, опреде¬ 
ленного командой ЗЕТ КЕРКОСЕ55. 

Для большей уверенности выполнения обновлений при 
обращении к разделенным данным, как и в режиме СІВА5Е, 
можно использовать команды транзакции ВЕОІИ и ЕЫй 
ТКАЫ5АСТІОЫ. Если операция транзакции не завершилась 
успешно, имеется возможность возвратить таблицы в исходное 
состояние, используя команду КОШЗАСК. 


Глава 5 

ПРАКТИЧЕСКОЕ ПРИМЕНЕНИЕ ЯЗЫКА 4ВА5Е IV 
ПРИ РАЗРАБОТКЕ ПРИКЛАДНЫХ ПРОГРАММ 

5.1. МОДУЛЬ ОРГАНИЗАЦИИ ВЫВОДА И ОБНОВЛЕНИЯ 
ДАННЫХ В ЗАДАЧЕ УЧЕТА ПЕРЕВОЗОК 

В гл. 2 был рассмотрен пример создания простой информационной задачи 
учета перевозок автотранспортным предприятием с помощью средств УЦ. В 
настоящей главе покажем, как расширить эту задачу, дополнив ее медулем 
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обработки информации, который создан с использованием командного языка 
сІВАБЕ IV. 

Модуль обработки информации по перевозкам с именем ОКІІ2 позволяет 
пользователю вводить, добавлять и удалять данные в экранной форме, 
представляющей собой карточку на водителя. В этой карточке, показанной ниже, 
высвечиваются данные из трех файлов БД с именами В01, В 02 , ВОЗ, структура 
которых приведена в гл. 2. 


Записи Перейти Выход 8:31:41рт 
ВОДИТЕЛЬ: Строков Олег Валерьевич Дата рождения 05/08/65 
Категория: В,С Стаж работы: 4 

АВТОМОБИЛЬ:ГАЗ-53 Номерной знак 34-56 ММД Находится в автопарке 
Техническое состояние: исправен 


Станки ЧПУ 

3.0 

Одинцово 

24/03/89 

Г орький 

25/03/8 


Мебель 

1.0 

Москва 

30/06/89 

Калуга 



Двигатели 

3.0 

Москва 

12/10/89 

Рязань 

14/10/8 



Р9:Таб|Р10:Меню|Рд0п:След. | РдІІр : Пред. | СТгІ-Рдйп : Поел. |СТг1-РдУр:Пер 


Экранная форма карточки состоит из верхней и нижней частей. В верхней 
части выводятся поля из файлов Вйі и ВЭ2, содержащие данные о водителе и 
его автомобиле, а в нижней (в виде стандартной формы Бгоѵѵзе) - поля из 
файла [ЮЗ, содержащие данные о перевозках, включая наименование груза, его 
вес, исходный и конечный пункты перевозки, дату выезда и прибытия, 
фактическое время нахождения в пути и расход горючего. Последние два поля 
не видны на рисунке, так как они расположены в скрытой правой части 
экранной формы Вгоѵѵзе. 

При эксплуатации информационной задачи учета перевозок требуется 
вводить новые данные в карточки водителей (данные о выполненных перевозках, 
состоянии автомобиля и т.д.), а также заводить новые карточки на вновь 
принятых водителей и удалять карточки уволенных водителей. После вызова 
модуля ѲРІІ2 высвечивается карточка водителя. 

Для обеспечения перечисленных операций служит основное (горизонтальное) 
меню с позициями "Записи", "Перейти" и "Выход", находящееся в верхней части 
экрана карточки. Это меню активизируется нажатием функциональной клавиши 
РІО. Ниже показаны позиции основного меню и прикрепляемые к ним 
вертикальные меню. 

Чтобы найти нужную карточку, можно перелистать их вручную клавишами 
РдЭп (вперед) и РдІІр (назад) или же использовать позицию "Перейти". При 
выборе этой позиции высвечивается вертикальное меню с позициями "Первая 
карточка", "Последняя карточка", "Карточка с номером", "Пропустить", "Поиск 
по фамилии". 
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Записи 


Перейти 


Выход 


Добавить новые карточки 


Пометить карточку для удаления 
Удалить помеченные карточки 


Первая карточка 
Последняя карточка 
Карточка с номером 
Пропустить 


Поиск по фамилии 


Выход из задачи 


Первые две позиции позволяют перейти соответственно к первой и 
последней карточкам водителей, фамилии которых упорядочены по алфавиту. 
Следующая позиция позволяет выбрать водителя по номеру его карточки. После 
выбора этой позиции высвечивается поле для ввода номера карточки. Для 
высвечивания карточки с заданным номером нужно по окончании ввода номера 
нажать клавишу Епіег. Для пропуска вперед или назад нескольких карточек 
нужно после выбора позиции "Пропустить'* ввести число пропускаемых карточек 
(со знаком "плюс" - вперед, а со знаком "минус" - назад). Высвечивание 
карточки по фамилии осуществляется выбором позиции "Поиск по фамилии", 
после чего высвечивается окно, в которое нужно ввести требуемую фамилию. 
Можно вводить фамилию не полностью, а лишь то число букв, начиная с 
первой, которое однозначно идентифицирует фамилию. Если в результате поиска 
требуемая карточка не найдена, то выдается сообщение "Такой карточки НЕТ!!!". 

Если же карточка найдена, она высвечивается на экране и с ней можно 
выполнять операции. Переход по полям карточки осуществляется клавишей ТаЬ, 
переход из верхней части карточки в нижнюю - клавишей Р9, а обратно - 
клавишей Езс. Обновление введенных данных (например, состояния автомобиля) 
осуществляется посредством установки курсора на нужное поле и изменения 
содержимого поля с клавиатуры. Фиксация исправлений выполняется клавишей 
Епіег. 

Удаление карточки реализуется в два этапа. Сначала нужно установить 
курсор на фамилию водителя и пометить ее, выбрав позицию "Пометить 
карточку для удаления". Таким способом можно пометить несколько карточек. 
Признаком пометки карточки является то, что вместо текста позиции "Пометить 
карточку для удаления" будет высвечиваться текст "Убрать пометку". Выбор 
последней позиции приводит к уничтожению пометки. 

Для того чтобы завести новую карточку, используется позиция "Добавить 
новую карточку" этого же меню. После ее выбора высвечивается пустая 
экранная форма ввода данных. 

В модуле предусмотрена возможность получить в любой момент работы 
справочную информацию: полные сведения о клавишах, которые используются 
при работе с экранной формой (краткая справка о клавишах всегда высвечивает* 
ся в нижней части экрана). Эта информация вызывается клавишей Р1. К 
справочной информации также относится сообщение - комментарий, высвечивае¬ 
мый в нижней строке экрана при выборе позиций меню. При высвечивании 
полной справочной информации экран имеет вид, показанный ниже. 

В данном разделе приводится текст модуля ѲК.ІІ2 с пояснениями о работе 
процедур и отдельных команд. Модуль ѲОД2 состоит из главной процедуры и 
вызываемых из нее процедур. 

В начале главной процедуры с помощью $ЕТ-команд выполняются установки 
параметров системы сіВАЗЕ IV. Затем определяются окна с именами ТаЫе, 
Раизе и 5сг_Ыр для высвечивания соответственно таблицы с данными о 
перевозках в нижней части карточки водителя, сообщений об ошибках при 
выполнении программы и справочной информации. Команда ОЫ Е&&ОК при 
возникновении ошибки вызывает процедуру Раизе. Этой процедуре передается 
параметр, содержащий имя процедуры и номер строки, в которой произошла 
ошибка. 


11 - 6340 
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Записи Перейти Выход 8:31:41рт 


ВОДИТЕЛЬ: Строков Олег Валерьевич Дата рождения 05/08/65 


Навигационные клавиши при работе с экранной формой: 


Р1: Вызов справочной информации 

Г9: Переход из верхней в нижнюю часть экранной формы 

Езс: Переход из нижней в верхнюю часть экранной формы 

РІО: Активизация меню экранной формы 

РдОп: Переход к следующей карточке 

Рдіф: Переход к предыдущей карточке 

СѣгІ-РдОп: Переход к последней карточке 

Сігі-Рдіір: Переход к первой карточке 


Нажмите любую клавишу ... 


Станки ЧПУ 

3.0 

Одинцово 

24/03/89 

Горький 

25/03/8 

Мебель 

1.0 

Москва 

30/06/89 

Калуга 

01/07/8 

Двигатели 

3.0 

Москва 

12/10/89 

Рязань 

14/10/8 


Р9:Таб|Р10:Меню|Рд0п:След. |РдІ)р:Пред. | СІгІ-РдОп :Поел. | Сіг 1-РдУр:Пер 


Команда &Е5ТО&Е МАСКОБ РКОМ вызывает макроопределения с именами 
Мели, ЕхН_Ьгоѵѵ и 1_іпеііет из файла макроопределений ТАВ.кеу. Эти 
макроопределения созданы предварительно средствами УЦ и предназначены для 
имитации нажатий клавиш. Макроопределение Мели предназначено для вызова 
клавишей РІО основного (горизонтального) меню. Это макроопределение 
имитирует нажатия последовательности клавиш СЫ-Епсі (сохранение текущей 
записи) и СИ-Р10 (передача в опцию САБЕ десятичного кода клавиши, 
служащего для идентификации вызова меню). Заметим, что вместо последней 
комбинации клавиш можно, в принципе, использовать любую комбинацию или 
отдельную клавишу, поставив ее десятичный код в опцию САБЕ. 

Макроопределение Ыпеііет предназначено для обеспечения перехода из 
верхней части карточки водителя в нижнюю при нажатии клавиши Р9. Оно 
включает имитацию последовательности клавиш СЫ-ЕпсІ (сохранение текущей 
записи) и СЫ-Р9. Функция последней комбинации аналогична комбинации 
СігІ-РІ 0 из предыдущего макроопределения. Макроопределение Ехіі_Ьго\ѵ 
служит для вывода таблицы Вгоѵѵзе в нижней части экранной формы и перехода 
в верхнюю часть и выполняется в процедуре БЬоѵѵЬгоѵѵ при высвечивании 
карточки водителя. Это макроопределение имитирует нажатие клавиши Е$с. 

1 СЬЕАК 

2 ЗЕТ СОЬОК ОР МЕЗЗАСЕ Іо Ш+/ВК * 

3 ЗЕТ СОІХЖ ОР ВОХ (о ІЯ/ВК 

4 ЗЕТ СОЬОН. ОР ІИРОКМАТЮИ іо N/811 

5 ЗЕТ СЬОСК ОЫ 

6 ЗЕТ ОЕЫМГГЕКЗ ОРР 

7 ЗЕТ ЕСНО ОРР 

8 ЗЕТ ТАЬК ОРР 

9 ЗЕТ ЕСНО ОРР 

10 ЗЕТ 5СОКЕВОАІШ ОРР 

И ЗЕТ ЗТАТІІЗ ОЫ 

12 

13 ОЕРІЫЕ ШІЫЕЮШ ТаЫе РКОМ 12,2 ТО 21,77 ЫОЫЕ СОЬОК *г+/п 
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14 ОЕРІЫЕ ШШЕЮШ Раисе РКОМ 14,01 ТО 19,78 ЫОЫЕ СОЬОК Ш+/К + 

15 БЕРШЕ \ѴЖІЮШ 8сг_Ыр РКОМ 5,00 ТО 20,79 ЫОЫЕ СОЬОК ОК+/В 

16 

17 ОЫ ЕККОК СЮ Раисе ШГГН "Программа "+Рговгат()+": "+"Строаа 

18 ІЛ , КІМ(8ТК(ІЛМЕ()))* 

19 КЕЗТОКЕ МАСК05 РКОМ ТЛВ 

20 


Далее команды ІІ$Е открывают файлы БД ЕЮ1, ВР2 и ЕЮЗ в рабочих 
областях 1, 2 и 3. Команды ОЫ КЕУ назначают клавишам Р1, Р9, Р10 

выполнение процедуры 5сг_Ыр и макроопределений Ыпеііет и Мели. 
Процедура Оеіптепи вызывается для определения основного горизонтального 
меню модуля С&ІІ2 и прикрепленных к его позициям вертикальных подменю. 

Символьной переменной дс_те$$д присваивается текст краткой справочной 
информации об используемых клавишах, который будет высвечиваться в строке 
сообщений экрана. Другим переменным присваиваются начальные значения, и 
после очистки 23-й строки экрана в ней высвечивается текст сообщения о 
функциях клавиш, записанный в переменной дс_те$5д. 

21 ЗЕЬЕСТ 3 

22 І15Е ВОЗ ОКОЕК п_г 

23 ЗЕТ САККѴ ТО п _2 

24 ЗЕЬЕСГ 2 

25 115Е В02.ЭВР ОКОЕК п_г 

26 ЗЕЬЕСТ 1 

27 113Е ВОІ.ЭВР ОКОЕК Гат 

28 

29 ОЫ КЕѴ ЬАВЕЬ Р1 IX) Зсг ЬІр 

30 ОЫ КЕѴ ЬАВЕЬ Р9 РЬАѴ МАСКО Ьіпсііст 

31 ОЫ КЕѴ ЬАВЕЬ Р10 РЬАѴ МАСКО Мепи 

32 ОО Оеіптепи 

33 ^с_тесс^ ="Р9іТабл. | Р10:Мсню | РдОп:След. | Р^ІІргПред.'; 

34 +" | Сіг1-РвОп:Послсд. | Сіг1-Р^ІІр:Псрвая" 

35 в п_ в огсс = 0 

36 В с пм1х=МОХ(1) 

37 В с ссагсЬ = 8РАСЕ(200) 

38 в с ссек = 8РАСЕ(ЬЕМ(Іат)) 

39 8І_псѵгсс = Л. 

40 8І_сЬлгес = .1. 

41 ^ІехІІоор = Л. 

42 

43 @ 23,0 

44 <§) 23,2 5АѴ в с _ тс88 8 

45 


Основой главной процедуры служит вложенная структура двух команд 
цикла ЭО ѴѴНІІ_Е...ЕЫООО. Выход из внешнего цикла осуществляется при 
присвоении переменной дІ_ехіІоор значения А. в процедуре Оеі_ехі1, которая 
вызывается при выборе позиции "Выход из задачи". Во внутреннем цикле 
выполняется разветвление управления в зависимости от значения переменной 
дп_іпкеу или дп_геасікеу. В переменную дп__іпкеу заносится значение 
десятичного кода последней нажатой клавиши или комбинации клавиш, 
возвращаемые функцией ІЫКЕУ(). При значении переменной дп_іпкеу = -19 
(десятичный код комбинации клавиш ОгІ-РІО, который служит признаком для 
высвечивания меню) выполняется активизация меню задачи. При значении этой 
переменной -18 осуществляется переход из верхней в нижнюю часть карточки 
водителя. В переменную дп_геасікеу заносятся значения десятичного кода 
клавиши или комбинации клавиш, которые возвращаются функцией КЕАРКЕУ() 
и нажаты пользователем в таблице Вгоѵѵзе. 
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Например, при нажатии клавиш РдІІр осуществляется переход к предыду¬ 
щей карточке, а при нажатии клавиш РдЭп - переход к следующей карточке. 
При этом если карточка последняя, то высвечивается предложение создать 
новую карточку и вызывается процедура РесаррепсІ, которая реализует операции 
по высвечиванию пустой карточки. Аналогично при нажатии клавиш СігІ-РдІІр или 
СігІ-РдОп осуществляется переход к первой или последней карточке, а при 
нажатии клавиш Е$с или С1Н-Еп4 - переход из таблицы Вгож&е в верхнюю часть 
карточки. 

В завершающей части главной процедуры команда ОЫ КЕѴ восстанавливает 
назначение клавишам Р1, Р9, РІО функций, заданных по умолчанию в 4ВА5Е IV, 
а команда ОЫ Е&&ОК - вывод системных сообщений об ошибках сіВАЗЕ IV. 
Команды &ЕІ.ЕА5Е удаляют из оперативной памяти все меню, окна, экран и 
переменные. 

46 IX) ѴѴНІЬЕ ЫОТ. ві ехііоор 

47 яп_геспо = КЕСЫО() 

48 &1 Ііпеііт = ЛГ. 

49 ОО \ѴНІЬЕ 8 1_1іпсііт 

50 ІР в1_сЬ^гсс 

51 ІЮ 5Ьош_^сІ 

52 ЕЫОІР 

53 IX) ЗЬоѵЬгоѵ 

54 IX) Е(Ш_кеІ 

55 КЕАЭ 

56 гсрітсс М2->п_г ѵі(Ь Ы11- >п_г 

57 

58 кпіпкеу = ІЫКЕѴ() 

59 К п геабкеу = КЕАОКЕѴ() 

60 ^с_гса<!ѵаг = ѴАККЕАО() 

61 КІ_1іпсйт = .Р. 

62 АСТІѴАТЕ 8СКЕЕЫ 

63 IX) СА8Е 

64 СА5Е *п іпксу = -18 

65 ІЮ Ьіпеііет 

66 ЗЫіпейт = .Т. 

67 СА8Е «п іпксу = -19 

68 АСТІѴАТЕ МЕЫЬІ Е<Штепи 

69 СА8Е ^п_гса6кеу = 6 .ОК. вп_геасікеу = 262 .(Ж.; 

70 вп_геа<1кеу = 260.ОК. &п_геа<1ксу = 4 

71 ІР .ЫОТ. ВОР() 

72 8КІР -1 

73 ЕЫОІР 

74 СА8Е ^п_геа6кеу = 7 .ОН. впгеасікеу = 263 .ОК.; 

75 вп_геа<)кеу = 5 .ОК. {п_геа(1кеу = 261 

76 8КІР 

77 ІР ЕОР() АЫО. .ЫОТ. *1_пешгес 

78 СЬЕАК ОЕТ8 

79 @ 23,0 

80 @ 23,22 8АѴ "=> Добавить новые карточки (V /ІЯ)? <=" ; 

81 СЕТ кі пеѵгес РІСТ "V 

82 КЕАЭ 

83 СЬЕАК СЕТ8 

84 @23,0 

85 @23,2 8АУ кс тсяк 

86 ЕЫОІР 
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87 ІР {І псѵгес 

88 ЕЮ Кссаррші 

89 ЕЬ5Е 

90 ІРЕОРО 

91 8К1Р -1 

92 ЕЫОІР 

93 ЕЛЕНЕ 

94 САЗЕ цпгеагікеу = 34 .ОК. догеайкеу = 290 

95 СО ТОР 

96 СА5Е ^п_гсас1кеу = 35 ОК. ^п гсаЛеу = 291 

97 СО ВОГТОМ 

98 СА5Е ^п гсаЛсу = 12 х>г. дпгеасікеу = 270 

99 діехііоор = .Т. 

100 ЕХГГ 

101 ЕЛЕ)СА$Е 

102 в1_сЬцгес = ІІР(до_геспо = К.ЕСЛО0, -Е-, Т.) 

103 ЕЛОЕЮ 

104 ЕЮ СЬкдеІс 

105 ЕЛОЕЮ 

106 ОЛ КЕѴ 

107 ОЛ ЕККОК 

108 5ЕЕЕСГ 1 

109 СШ8Е АІХ 

110 КЕЬЕАЗЕ МЕЛЫ ЕсШтспи 

111 КЕЫЕА5Е РОРЕІР5 КесогсЬ, Сот, Ехіі 

112 КЕЬЕАЗЕ ШІЛЕЮ1Ѵ5 ТаЫс^аияг^сскЗсагсЬЗ^ягсЬ^сг ЬІр 

113 КЕЬЕАЗЕ 1с_Іа1к4с_Пе1<1*4с_*иіи*4с свсаре 

114 КЕТЫКЛ 

115 


Из главной процедуры вызываются следующие процедуры: 5Ьоѵѵ_деі, ЕсМ_деі, 
ЗЬоѵѵЬгоѵѵ, Ыпегіет, Кеузеі, КеукіІІ, СЬксІеІе, 

КесаррпсІ, Оеі_гесз, Оеі_ до*о, Ое*_ехіі, Раиве, 5сг_Ыр, йеіптепи. 

Процедура Оеіптепи определяет основное (горизонтальное) меню данного 
модуля с именем Есііітепи и прикрепленные к его позициям вертикальные меню 
с именами Кесогсіі, 6о__іо, Ехіі, а также окно с именем $еек, в которое вводится 
фамилия при поиске карточки. 

Эти меню позволяют выполнять различные операции над записями БД, а по 
окончанию рабдты выйти в УЦ. В начале процедуры определяется горизонтальное 
меню с именем Есііітепи, состоящее из трех позиций "Записи", "Перейти" и 
"Выход", расположенных в нулевой строке экрана. К позициям горизонтального меню 
прикрепляются вертикальные меню. Командами ОЫ РАО назначается активизация 
вертикальных меню с именами Кѳсогсів, Оо_1о или Ехіі при выборе позиций 
горизонтального меню с теми же именами. 

Далее определяется вертикальное меню с именем Кѳсогсів, имеющее три 
активные позиции. Это меню выполняет действия по добавлению новой карточки в 
файл БД, пометке для удаления или отмены пометки текущей карточки, а также 
удаление помеченных карточек. 

В следующих строках определяется вертикальное меню с именем 5о_1о. Это 
вертикальное меню реализует функции поиска первой, последней и карточки с 
заданным номером, пропуск вперед и назад требуемого числа карточек и поиск 
карточки по фамилии. 
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Вертикальное меню Ехіі состоит из одной позиции, при выборе которой 
осуществляется выход из задачи. 

Командами ОЫ 5ЕІ.ЕСТІОЫ РОРІІР определяются процедуры, которые будут 
выполняться при активизации вертикальных меню. При активизации меню с именами 
Кесогсіз, Оо_іо и Ехіі выполняются соответственно процедуры с именами Оеі_гесз, 
Ѳеі_доіо и Оеі_ехіі. 

В конце процедуры РЫптепи команда ОЕРІЫЕ ѴѴІЫООѴѴ определяет окно с 
именем Беек, а команда 5НО\Л/ МЕЫІІ высвечивает в верхней строке экрана позиции 
горизонтального меню ЕсШтепи, но не активизирует его. 

116 РКОСЕОІЖЕ ОеГптепи 

117 ЗЕТ ВОКБЕК ТО ЗІЫСЬЕ 

118 ОЕРІЫЕ МЕЫ11 ЕсШтепи 

119 ОЕРІЫЕ РАО Кесогйс ОР ЕсШтепи РКОМРТ -Записи - ЛТ ОД 

120 ОЕРІЫЕ РАО Со_Ю ОР ЕсШтепи РКОМРТ "Перейти" АТ 0,14 

121 ОЕРІЫЕ РАО Ехіі ОР ЕсШтепи РКОМРТ -Выход 'АТ0Д6 

122 ОЫ РАО КесопЬ ОР ЕсШтепи АСТІѴАТЕ РОРЫР КссогЛ 

123 ОЫ РАО Соіо ОР ЕсШтепи АСТІѴАТЕ РОРІІР Со_Ю 

124 ОЫ РАО Ехіі ОР ЕсШтепи АСТІѴАТЕ РОРІІР Ехіі 

125 

126 ОЕРІЫЕ РОРІІР Кесогск РКОМ 2,0 

127 ОЕРІЫЕ ВАК 1 ОР Кесогск РКОМРТ " Добавить новые карточки - 

128 ОЕРІЫЕ ВАК 2 ОР КесогсЬ РКОМРТ ■-" 5КІР 

129 IX) СЬксіеІе 

130 ОЕРІЫЕ ВАК 4 ОР Кесогй* РКОМРТ - Удалить помеченные карточки"; 

131 МЕЗЗАСЕ -Физическое удаление помеченных карточек в БД- 

132 

133 ОЕРІЫЕ РОРІІР Со іо РКОМ 2,12 

134 ОЕРІЫЕ ВАК 1 ОР Со Іо РКОМРТ - Первая карточка*; 

135 МЕЗЗАСЕ "Перейти к первой карточке БД" 

136 ОЕРІЫЕ ВАК 2 ОР Со іо РКОМРТ " Последняя карточка*; 

137 МЕЗЗАСЕ "Перейти к последней карточке БД- 

138 ОЕРІЫЕ ВАК 3 ОР Со іо РКОМРТ ■ Карточка номер"; 

139 МЕЗЗАСЕ "Перейти к карточке с указанным номером- 

140 ОЕРІЫЕ ВАК 4 ОР Со іо РКОМРТ " Пропустить'; 

141 МЕЗЗАСЕ 'Число пропускаемых карточек (знак - переход назад)’ 

142 ОЕРІЫЕ ВАК 5 ОР Со іо РКОМРТ 4 - * 5КІР 

143 ОЕРІЫЕ ВАК 6 ОР Со_Ю РКОМРТ " Быстрый поиск по фамилии * ; 

144 МЕЗЗАСЕ "Применяется для поиска по индексу при заданном значении- 

145 

146 ОЕРІЫЕ РОРІІР Ехіі РКОМ 2,22 

147 ОЕРІЫЕ ВАК 1 ОР Ехіі РКОМРТ " Выход из задачи учета перевозок "; 

148 МЕЗЗАСЕ "Сохранить изменения в текущей карточке и выйти из задачи- 

149 ОЫ ЗЕБЕСПОЫ РОРІІР КесогсЬ ІЮ Сеігес* 

150 ОЫ ЗЕБЕСПОЫ РОРІІР Со іо ІЮ СеІ_во(о 

151 ОЫ 5ЕБЕСПОЫ РОРІІР Ехіі ІЮ Сеі ехіі 

152 

153 ОЕРІЫЕ Ѵ/ІЫІЮДѴ Зсек РКОМ 8,15 ТО 11/44 

154 ОЕРІЫЕ Ѵ/ІЫІЮШ ЗеагсЬ РКОМ 9,15 ТО 11/60 

155 ОЕРІЫЕ ѴПГООФ ВвеагсЬ РКОМ 10,15 ТО 12,60 

156 5НОѴ/ МЕЫІІ ЕсШтепи 

157 КЕПІКЫ 

158 


Процедура СЬксіеІе вызывается при активизации вертикального меню Кесогсіз 
и высвечивает различный текст во второй его позиции в зависимости от того, 
помечена ли текущая карточка. Если она помечена для удаления, то в этой 
позиции меню высвечивается текст "Убрать пометку". Если же карточка не 
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карточку для 


* 


помечена для удаления, то высвечивается текст "Пометить 
удаления". 

159 РКОСЕЕНЖЕ СЬкЛеІе 

160 ІР ОЕЬЕТЕЕЮ 

161 ОЕРІЫЕ ВАК 3 ОР Кеоопк РКОМРГ " Убрать пометку *; 

162 МЕ8ЯАСЕ "Восстановление карточки, помеченнном для удаления* 

ІбЗЕЬЗЕ 

164 ОЕРІ1ЧЕ ВАК 3 ОР КесогсЬ РКОМРТ " Пометить карточку для удаления*; 

165 МЕЗЗАОЕ Пометка карточки, предназначенной для удаления* 

166 ЕЫЭІР 

167 КЕШКИ 

Процедура 5ЬожЬгож обеспечивает вывод в таблице Вгоѵѵзе тех записей о 
перевозках, которые выполнены водителем, карточка которого высвечена на 
экране. Вывод таких записей реализуется командой $ЕТ РИТЕК, которая в файле 
БД ВйЗ отбирает записи, относящиеся к этому водителю. Процедура только 
высвечивает записи в таблице Вгож$е, но не дает возможности их редактировать. 

168 

169 РКОСЕОІЖЕ ЗЬоѵЬгоѵ 

170 ЗЕЬЕСТ 3 

171 ЗЕТ РІЬТЕК ТО 

172 ЗЕЕК Ьаі->п_г 

173 ІР ЕОР() 

174 АРРЕИО ВЬАИК 

175 КЕРЬАСЕп г\ѴГГНІч11->п г 

176 ЕИБІР 

177 ЗЕТ РІІ.ТЕК ТО п г = М1->п_г 

178 ОО ТОР 

179 РЬАѴ МАСКО ЕжііЬгош 

180 ВКО^УЗЕ РІЕЬОЗ п_в,ѵе*,о_р,с1_ѵД_(1,гі_р,ѵгт,гяг,п_г ; 

181 ѴѴІИЕЮШ ТаЫе СОМРКЕЗЗ ИОМЕИУ ИОСЬЕАК 

182 5ЕІ.ЕСТ 1 

183 АСТІѴАТЕ ЗСКВЕИ 

184 КЕШКЫ 

185 


Процедура ипейет в отличие от процедуры БНоѵѵЬгоѵѵ предоставляет 
возможность пользователю в таблице Вгоѵѵзе редактировать записи по 
перевозкам, выполненным водителем, и вызывается после нажатия функциональ¬ 
ной клавиши Р9 (переход в нижнюю часть карточки водителя). В начале этой 
процедуры посредством вызова процедуры КеукіІІ осуществляется подавление 
функций, ранее назначенных клавишам Р1, Р9 и РІО. Заметим, что функции этих 
клавиш, заданные по умолчанию в сіВАЗЕ IV, не восстанавливаются, т.е. они 
просто закрываются для пользователя. 


186 РКОСЕОІЖЕ Ілпеііет 

187 1п_кеу - ІЫКЕѴ() 

188 ІЮ КеукіІІ 

189 5ЕІ.ЕСТ 3 

190 ІР ЕОР() 

191 АРРЕОД ВІАЫК 

192 КЕРЬАСЕ п т Ѵ/ГГН ЫП->пг 

193 ЕЫБІР 

194 ЗЕТ РІЬТЕК ТО п_г = Ь01->п_г 

195 ОО ТОР 

196 ВКОФ5Е РІЕЬОЗ п_|,ѵеі,о_р,<1_ѵ^_<І,<і_р,ѵгт,г*г^_г ; 
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197 ѴѴІЫЕЮШ ТаЫе СОМРЕЕ88 ЫОМЕЫІІ ЫОСЬЕАК 

198 АСТІѴАТВ 8СКЕЕЫ 

199 ЕЮ Кеук( 

200 8ЕІ.ЕСТ 1 

201 ЕЕТІЖЫ 

202 


Процедура Кеугеі осуществляет назначение функций клавишам Р1, Р9, РІО, 
которые предусмотрены в данном модуле в отличие от принятых по умолчанию 
в сІВАЗЕ IV. 


203 РЕОСЕОІЖЕ Кеулсі 

204 ОЫ КЕѴ ЬАВЕЬ Р1 ЕЮ 8сг_Ыр 

205 ОЫ КЕѴ ЬАВЕЬ Р9 РЬАѴ МАСЕО Ілпеііеш 

206 ОЫ КЕѴ ЬАВЕЕ Р10 РЬАѴ МАСЕО Мепи 

207 ЕЕТІЖЫ 

208 


Процедура КеукіІІ отменяет функции, которые были назначены функциональ¬ 
ным клавишам Р1, Р9, РІО, посредством выполнения фиктивной команды - 
занесения в переменную Іп_кеу значения нажатой клавиши. 

209 РЕОСЕОІЖЕ КеукіІІ 

210 ОЫ КЕѴ ЬАВЕЬ Р1 Іпкеу-ІЫКЕѴ() 

211 ОЫ КЕѴ ЬАВЕЬ Р9 Іпкеу =ІЫКЕѴ() 

212 ОЫ КЕѴ ЬАВЕЕ. Р10 Іп кеу =ІЫКЕѴ() 

213 ЕЕТІЖЫ 

214 


Процедура КесаррпсІ осуществляет переход к последней карточке БД, 
добавляет в конец файлов БД В01 и ЕЮ2 пустую запись и высвечивает пустую 
карточку водителя. 

215 РЕОСЕОІЖЕ Еесаррпсі 

216 АРРЕЫО ВЕАМК 

217 ^1_пеѵгес =.Г. 

218 ЕЕТ1ЖЫ 

219 


Процедура Сеі_гес$ обеспечивает реализацию функций вертикального меню 
Кесогсіз, имеющего три активные позиции: "Добавить новую карточку", 
"Пометить карточку для удаления" ("Убрать пометку") и "Удалить помеченные 
карточки". 

220 РЕОСЕОІЖЕ Сергее* 

221 ЕЮ СА8Е 

222 СА8Е ВЛЕ() = 1 &А добавление 

223 ЕЮ Вссаррп4 

224 СА8Е ВАЕ() = 3 && пометка/восстановление 

225 1Р ОЕЬЕТЕО() 

226 ЕЕСАІХ 

227 8ЕЬЕСТ 3 

228 ЕЕСЛІХ АЬЬ 

229 8ЕІ.ЕСТ 2 

230 ЕЕСАІХ 

231 ЕЬ8Е 

232 ОЕЬЕТЕ 

233 8ЕЬЕСТ 3 
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234 ОВЬЕТЕ АЬЬ 

235 ЗЕЬЕСТ 2 

236 ОВЬЕТЕ 

237 ЕЫОІР 

238 8ЕЬЕСГ 1 

239 САЗЕ ВАК() - 4 АА удаление 

240 РЛСК 

241 8ЕЬЕСТ 3 

242 РАСК 

243 8ЕЬЕСГ 2 

244 РАСК 

245 8ЕТ ОІШЕК ТО Ы_2 

246 ЕЫОСА8Е 

247 ОО СЬкбеІе 

248 ОЕАСГГѴАТЕ МЕЫЫ 

249 КЕТІІКЫ 

250 


Процедура С®1_доіо реализует функции вертикального меню Ооіо по 
переходу к первой и последней записи файла БД, записи с заданным номером, 
пропуск вперед и назад заданное число записей, а также поиск по фамилии. 
Разветвление управления реализуется с помощью команды ЭО СА5Е... ЕЫОСА5Е. 
Первые две функции выполняются командами ОО ТОР и ОО ВОТТОМ, 
расположенными после соответствующих опций САЗЕ. При поиске по номеру 
карточки в команду @...ОЕТ включена опция (^АЫОЕ для проверки того, не 
выходит ли номер вводимой карточки за пределы первой и последней записи. 
Если выходит, то высвечивается системное сообщение сіВАЗЕ IV, в котором 
указывается заданный диапазон. 

Для реализации функции пропуска заданного числа карточек при выборе 
позиции "Пропустить" введенное с клавиатуры число заносится в переменную 
зкіргес, которая затем используется в команде 5КІР. 

При реализации функции поиска карточки по фамилии введенная с 
клавиатуры фамилия заносится в переменную дс__$еѳк, которая используется 
вместе с командой ЗЕЕК. Если в файле БД нет водителя с такой фамилией, 
вызывается процедура Раи$е и в окне высвечивается сообщение "Такой фамилии 
в списке нет !!!". 

251 РКОСЕОІШЕ СеІ_ 8 оЮ 

252 трісі - КЕРЫСАТЕ("9", ЬЕЫ( ЬТКІМ( 8ТК( КЕССОЕІЫТО)))) 

253 §с_*еагсЬ = СсвеагсЬ + 8РАСЕ(200 - ЬЕМ(СсвеагсЬ)) 

254 8 с_ссск = Ссссск + 8РАСЕ(ЬЕЫ(РАМ) - ЬЕЫ(Сс_*сек)) 

255 ЕЮ САЗЕ 

256 САЗЕ ВАК () = 1 

257 СО ТОР 

258 САЗЕ ВАК() = 2 

259 СО ВОТТОМ 

260 САЗЕ ВАК() = 3 

261 @ 5,39 СЕТ іп ^отсс КАЫСЕ 1, КЕССОІЛЧТ() РІСТЕІКЕ Мрісі 

262 КЕАО 

263 8П_8<>гес = ІІР( Оп_8огес*0, КЕСИОО, Сп_ 80 гес) 

264 ОО (п^огес 

265 САЗЕ ВАК() = 4 

266 скіргес = ІІР( КЕССОиИТО > 9, 10, 5) 

267 @ 5 Зв СЕТ акіргес РІСТІЖЕ Мрісі 

268 КЕАБ 

269 8К1Р вкіргсс 

270 ІР ЕОР() 

271 ЗКСІР -1 
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272 ЕЫОІР 

273 САЗЕ ВАВ() = 6 

274 АСГГѴ АТЕ ФІЫІЮФ Зеек 

275 ІР "" = ОВОЕВ() 

276 (етрпиіх = ТАС(2) 

277 ЗЕТ ОІШЕК ТО ТАС Діетрпиіх. 

278 ЕЫОІР 

279 @ ОД ЗЛУ 'Введите фамилию водителя" 

280 @14 СЕТ *ссеек РІСТ "@320" МЕЗЗАСЕ "Отменить: Есс" 

281 ВЕЛО 

282 ІР ВЕАОКЕУ() о 12 

283 зс веек = ЬТВІМ( ТКІМ(вс іеек)) 

284 тгес = КЕСЫО() 

285 ЗЕЕК *ссеек 

286 ір .ыотГрооыоо 

287 ІЮ Раисе ШГГН "Такой фамилии в списке нет !!!" 

288 СО тгес 

289 ЕЫОІР 

290 ЕЫОІР 

291 ОЕАСГІѴАТЕ >ѴІМІЮ\Ѵ Зеек 

292 АСТІѴАТЕ ЗСВЕЕЫ 

293 ЕЫІЮАЗЕ 

294 ОЕАСТІѴАТЕ МЕЫІІ 

295 ВЕТІЖЫ 

296 


Процедура вызывается при выборе позиции вертикального меню 

Ехіі. В ней выполняется команда СІ.ЕА& СЕТ5 по очистке полей переменных 
команд СЕТ, затем переменной дІ_ех1Іоор присваивается значение .Т., для 
обеспечения выхода из цикла йО ѴѴНИЕ...ЕЫОРО в главной процедуре и 
деактивизируется основное горизонтальное меню ЕсШтепи. 

297 РВОСЕОІЖЕ СеІехіІ 

298 СЬЕАВ СЕТЗ 

299 дІехПоор = .Т. 

300 ОЕАСТІѴАТЕ МЕЫІІ 

301 ветіжы 

302 


Процедура Раиіе вызывается при возникновении ошибки в программе и 
выводит в окне Раизе информацию о характере ошибки, имя процедуры и 
номер строки, в которой она произошла. 

303 РВОСЕОІЖЕ Раисе 

304 РАВАМЕТЕВ 1с_тс 8 

305 ІР ТѴРЕ("1с_тессаве") =41" 

306 Сп_еггог =ЕВВОВ() 

307 ЕЫОІР 

308 Істсд = 1с_тс& 

309 1с_ор(іоп =’0’ 

310 АСТІѴАТЕ \ѴІЫСЮ\Ѵ Раисе 

311 ІР дп_еггог > о 

312 ІР ТУРЕ("1с_тесса8е")="ІІ" 

313 @ 0,1 ЗАУ [Произошла ошибка !! - Сообщение: ]+МЕ55АСЕ() 

314 ЕЬЗЕ 

315 @ ОД ЗАУ [Ошибка # ]-Ис_тессаве 

316 ЕЫОІР 

317 ЕЫОІР 

318 @ 2,10 8АѴ Істс* 
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319 >ѴАГГ ' ... нажмите любую клавишу " 

320 ОЕАСГІѴАТЕ ѴІЫЕЮШ Раи*е 

321 КЕТІЖЫ 

322 


„ Процедура 5сг_Ыр вызывается при нажатии клавиши Р1 и высвечивает в 
окне НІр справочную информацию о клавишах, используемых в задаче. Сначала 
высвечивается текст, объясняющий использование клавиш при работе в верхней 
части карточки водителя, затем после нажатия любой клавиши в окне появляется 
информация о клавишах, используемых при работе с таблицей Вгоѵѵзе в нижней 
части карточки водителя. 

В этой процедуре используется команда ТЕХТ...ЕЫОТЕХТ, позволящая вывести 
на экран текст, введенный в программу. 

323 РКОСЕОШШ 8сг_Ыр 

324 {с_геа<1ѵаг = ѴАККЕАО() 

325 АСТIVАТЕ ШІМХЭДѴ $сг_Ыр 

326 СХЕАК 

327 ТЕХТ 

328 Навигационные клавиши при работе с экранной формой: 

329 - 

330 

331 Р1: Вызов текста экрана помощи 

332 Р9: Переход из экранной формы в таблицу 

333 РІО: Активизация меню для экранной формы 

334 

335 Р^Оп: Переход к следующей записи экранной формы 

336 Р^Пр: Переход к предыдущей записи экранной формы 

337 СігІ-Р^Оп: Переход к последней записи БД, поля 

338 которых размещены в экранной форме 

339 СігІ-Р^ІІр: Переход к первой записи БД 

340 

341 Евс: Выход из задачи 

342 ЕЫОТЕХТ 

343 @ 14,5 вау "Нажмите любую клавишу ..." 

344 х = ІЫКЕѴ(О) 

345 СБЕАК 

346 ТЕХТ 

347 Навигационные клавиши при работе с таблицей: 

349 

350 Р1: Вызов текста экрана помощи 

351 

352 РДОп: Переход к следующему экрану в таблице 

353 Р^ІІр: Переход к предыдущему экрану в таблице 

354 СігІ-РдОп: Переход к последней строке таблицы 

355 СігІ-Р^Пр: Переход на первую строку таблицы 

356 

357 Еве: Возвращение в экранную форму 

358 ЕЫОТЕХТ 

359 @ 145 вау "Нажмите любую клавишу..." 

360 х = ІЫКЕѴ(О) 

361 ОЕАСГІѴАТЕ \ѴІЫЕЮ\Ѵ Зсг Ыр 

362 АСТІѴАТЕ 8СКЕЕЫ 

363 КЕТШМ 

364 
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Процедура 5Ьоѵѵ__де1 создает верхнюю часть экрана карточки водителя и 
обеспечивает форматированный вывод полей из файлов баз данных ЕЮ1, ЕЮ2 
с пояснительными записями. 

365 РКОСЕОІЖЕ $Ьоѵ_кеІ 

366 @ 2,0 8АУ ■ * 

367 @ 23 5АУ " |-"; 

368 +■- 1 ■ СОІХЖ п/г 

369 @ 33 ЗАУ ■ | " СОІХЖ п/г 

370 @ 33 ЗАУ " • СОНЭК 8 г+/г 

371 @ 3,4 8АУ -ВОДИТЕЛЬ:* СОЬОК ш+/г 

372 @ 3,13 8АѴ ' - СОІХЖ *г+/г 

373 @ 3,14 ОЕТ М1->Гат РІСТІЖЕ "ХХХХХХХХХХХХХХХ* СОІХЖ п/Ь^.п/Ь* 

374 @ 339 8АУ * ■ СОІХЖ *г+Д 

375 @ 330 ОЕТ Ь41->пат РІСТІЖЕ "ХХХХХХХХХХХХХХХ" СОІХЖ п/Ь&.п/Ь* 

376 @ 3,45 8АУ " * СОІХЖ *г+/г 

377 @ 3,46 ОЕТ ЬгіІ-ХМс РІСТІЖЕ "ХХХХХХХХХХХХХХХ" СОЬОК п/Ь^.п/Ь^ 

378 <Э 3,61 8АУ " г.р. " СОІХЖ *г+/г 

379 @ 3,68 ОЕТ ЫИ-Хіг СОІХЖ п/Ь*,п/Ь 8 

380 @ 3,76 8АУ " - СОІХЖ *г+/г 

381 @ 3,77 8АУ -I " СОБОК п/г 

382 @ 43 ЗАУ • [" СОЬОК п/г 

383 @ 43 ЗАУ • •; 

384 +• " СОІХЖ %т+/т 

385 @ 4,77 8АУ "I ■ СОЬОК п/г 

386 @ 53 ЗАУ " I " СОІХЖ п/г 

387 <» 53 8АУ * Категория: ■ СОІХЖ К г+/г 

388 @ 5,15 СЕТ Ы1->ка( РІСТІЖЕ "ХХХХХХХХХ" СОІХЖ п/Ь 8 ,п/Ь в 

389 @ 534 8АУ " Стаж работы: " СОЬОК *г+/г 

390 @ 5,40 СЕТ М1->«_г РІСТІЖЕ "99" СОІХЖ п/Ь*,п/Ь 8 

391 @ 5,42 8АУ ■ • СОІХЖ В г+/г 

392 @ 5,77 8АУ ■ | ■ СОЬОК п/г 

393 @ 63 ЗАУ " | " СОІХЖ п/г 

394 @ 63 ЗАУ " 

395 +" " СОІХЖ В г +/г 

396 @ 6,77 8АУ * | - СОІХЖ п/г 

397 @ 73 ЗАУ * | " СОЬОК п/г 

398 @ 73 ЗАУ " 

399 +■ " СОІХЖ 8 г+/г 

400 @ 7,77 8АУ -1" СОІХЖ п/г 

401 @ 83 ЗАУ • | " СОІХЖ п/г 

402 @ 83 ЗАУ * " СОІХЖ *г+/г 

403 @ 8,4 8АУ "АВТОМОБИЛЬ:" СОІХЖ Ь*+/г 

404 @ 8,15 8АУ " " СОЬОК *г+/г 

405 @ 836 8АУ " номерной знак " СОІХЖ &г+/г 

406 @ 8,43 ОЕТ Ь61->п_г РІСТІЖЕ -ХХХХХХХХХ" СОІХЖ п/Ъ^п/Ь* 

407 @ 832 8АУ ■ находится " СОІХЖ *г+/г 

408 ЕЮ Васе2 

409 @ 8,16 ОЕТ таг РІСТІЖЕ "ХХХХХХХХХХ" СОЬОК п/Ь*,п/Ь 8 

410 @ 8,64 ОЕТ *_п РІСТІЖЕ "XXХХХХХХХХХХ" СОІХЖ п/Ъ 8 ,п/Ь 8 

411 @ 932 СЕТ со* РІСТІЖЕ "ХХХХХХХХХXXX" СОІХЖ п/Ъ 8 ,п/Ъ 8 

412 @ 8,76 8АУ " " СОІХЖ 8 г+/г 

413 @ 8,77 8АУ ■ | ■ СОІХЖ п/г 

414 @ 93 ЗАУ * | * СОІХЖ п/г 

415 @ 93 ЗАУ " техническое состояние:" СОІХЖ цг+/ г 

416 @ 934 ЗАУ * " СОІХЖ *г+/г 

417 @ 9,77 8АѴ "I ■ СОІХЖ п/г 

418 @ 103 8АУ * *- 

419 +"- 1 " СОІХЖ п/г 
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420 СЬЕАК СЕГ5 

421 8ЕЦБСГ 1 

422 КЕТОНЫ 

423 


Процедура Е4іі_деі высвечивает поля файлов баз данных ЕЮ1 и ЕЮ2. В 
главной процедуре после команды вызова процедуры Е4іі__деі следует команда 
КЕАР, активизирующая команды @...ОЕТ, находящиеся в процедуре, в результате 
чего становится возможным вводить и изменять высвечиваемые поля. 

424 РКОСЕОЧКЕ Е<Ш_цеІ 

425 @ 3,14 ОЕТ М1->(аш РІСТОКЕ "ХХХХХХХХХХХХХХХ’ СОЬОК п/Ь*,п/Ь* 

426 @ 330 СЕТ ккИ->пат РІСТОКЕ "ХХХХХХХХХХХХХХХ' СОЬОК п/Ь В ,п/Ь* 

427 @ 3,46 ОЕТ Ь61->оІс РІСТОКЕ -ХХХХХХХХХХХХХХХ" СОЬОК п/Ъ*,п/Ь& 

428 @ 3,68 СЕТ ЬсІ 1->6_г СОІ.ОК п/Ь^.п/Ь^ 

429 @ 5,15 СЕТ Ы11->каС Р1СТОКЕ "ХХХХХХХХХ" СОЬОК п/Ь&,пД>я 

430 @ 5,40 СЕТ Ь61->9 Г РІСТОКЕ "99* СОЬОК п/Ь К ,п/Ь* 

431 @ 8,43 СЕТ ЫИ->иГг Р1СТОКЕ -ХХХХХХХХХ" СОШК п/Ь 8 ,п/Ь 8 

432 ІЮ Васе2 

433 @ 8,16 СЕТ таг РІСТІЖЕ "ХХХХХХХХХХ" СОЬОК п/Ьв,п/Ь В 

434 @ 8,64 ОЕТ *_п РІСТОКЕ -ХХХХХХХХХХХХ' СОЬОК п/Ъ&,п/Ъ В 

435 @ 932 СЕТ со* РІСТОКЕ -ХХХХХХХХХХХХ" СОЬОК п/Ь 8 ,п/Ь& 

436 5ЕЬЕСГ 1 

437 КЕТОКЫ 

438 


Процедура Ва$е2 служит для установки поля п _2 в качестве управляющего 
индекса, поиска записи в файле ВР2 с номером знака, выбранным из этого поля 
в текущей записи файла ВЭ1, или занесения этого номера, если такой записи 
нет. 

439 РКОСЕОІЖЕ Вавс2 

440 ЗЕЬЕСТ 2 

441 5ЕТ ОКБЕК ТО о г 

442 8ЕЕК М1->п_г 

443 ІР ЕОР() 

444 АРРЕЫЭ ВЬАЫК 

445 КЕРЬАСЕ п_г ШІТН ЫІ1->п г 

446 ЕЫОІР 

447 КЕТОКЫ 


5.2. БИБЛИОТЕЧКА ПРОЦЕДУР. РЕАЛИЗУЮЩИХ 
СТАНДАРТНЫЕ ФУНКЦИИ 

В данном разделе описывается библиотечка процедур, которые можно 
использовать (возможно, с некоторыми добавлениями и изменениями) в качестве 
элементов для построения прикладных программ. В библиотечку входят 
следующие процедуры: Оиіриі.ргд, Іприі.ргд, Кеу.ргд, Неір.ргд, Мпиргіпі.ргд, 
Еггог.ргд, АррепсІ.ргд, Мепи.ргд, Мизіс.ргд. Ниже приводится их описание вместе 
с текстом команд. 

Процедура Оиіриі позволяет отобрать по заданному условию данные из 
файла БД и вывести их порциями на экран. После вывода очередной порции 
пользователю предоставляется возможность продолжить просмотр отобранных 
данных или прекратить вывод и выйти из программы. 

Отбор данных осуществляется из файла базы данных ВР1, который 
рассматривался в задаче учета перевозок в гл. 2, по полю даты рождения, 
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а на экран выводятся поля (ат (фамилия), лат (имя), оіс (отчество), 6_г (дата 
рождения). 

В начале процедуры команда ЗЕТ ЕСНО ОРР подавляет вывод на экран 
выполняемых команд, а команда ЗЕТ ТАІ.К ОРР отменяет вывод результатов 
выполнения команд. Команда ЗЕТ РАТЕ ѲЕ&МАЫ устанавливает европейский 
формат даты - ДД.ММ.ГГ, где ДД - число месяца, ММ - номер месяца, ГГ - 
год. 

Далее переменным рсіаі 1 и рсЫ2 присваиваются начальные значения 
рсІаН = {01.01.35} и рсЫ2 = РАТЕ(), первой из них - значение некоторой даты, а 
второй - значение текущей даты, в результате чего тип этих переменных 
становится датой. 

Затем создается экранная форма для ввода условия отбора данных. 
Команда @ 7,22 ТО 15,52 рисует на экране рамку, @..5АѴ высвечивает 
пояснительный текст: "ВВЕДИТЕ", "-начальную дату:", "-конечную дату:", а две 
команды @...СЕТ выводят начальные значения рсіаіі, рсІаі2 интервала отбора 
записей по дате рождения, которые заменяются требуемыми. 

Команда &ЕАР активизирует команды @...ОЕТ, т.е. обеспечивает запись в 
переменные рсЫІ, рсІа!2 значений, которые вводятся с клавиатуры. Команда ІІ5Е 
открывает файл БД с именем В01, из которого в соответствии с заданным с 

помощью команды ЗЕТ РІІ-ТЕК ТО сі г >= рсіаИ .АИй. сі г <= рсЫ2 

фильтром отбираются требуемые записи. 

После фильтрации командой СО ТОР осуществляется переход на первую 
отобранную запись. Команда ЗЕТ РІЕІ.03 ТО 1ат,пат,оіс,сІ _ г определяет перечень 
выводимых на экран полей, а С1_ЕАР очищает экран. 

Вывод отобранных записей на экран осуществляется с помощью цикла ЭО 
\ѴНІІ_Е...ЕЫООО. Команда ? выводит заголовок "Фамилия Имя Отчество Дата 
рождения", а команды ЭІЗРІ-АѴ ОРР ЫЕХТ 5 - очередные пять записей. Затем 
пропускается пустая строка (команда ?), вывод записей приостанавливается и 
высвечивается сообщение "Для продолжения вывода нажмите любую клавишу. 
Для прекращения вывода - клавишу V". Вывод этого сообщения с одновремен¬ 
ной приостановкой выполнения программы осуществляется командой ѴѴАІТ, 
которая также вводит в переменную рѵ код нажатой клавиши, после чего 
происходит идентификация этой клавиши. При этом используется функция 
1)РРЕК(), преобразующая строчную букву в прописную, поскольку в программе 
задан выход только по прописной букве. Тем самым пользователю предоставля¬ 
ется возможность нажимать для выхода как прописную, так и строчную букву 
ѵ, которые имеют разные коды АЗСІІ. Если нажата буква V, то командой ЕХІТ 
осуществляется выход из цикла РО ѴѴНИЕ...ЕЫООО и выполняются команды, 
завершающие программу - закрытие фильтра и файла. Нажатие любой другой 
клавиши приводит к продвижению на одну запись указателя записей файла 
(командой ЗКІР) и повторению цикла операций. При этом реализуется проверка 
на конец файла, и если он обнаружен, то также выполняется выход из цикла 
и завершение программы. 

* Оиіриі.рг# 

1 ЗЕТ ЕСНО ОРР 

2 ЗЕТ ТАЬК ОРР 

3 ЗЕТ БАТЕ СЕКМАЫ 

4 

5 р<*а11=СГОО(-01.0135 в ) 

6 р<1а(2 =ОАТЕ() 

7 @ 7,22 ТО 15,52 

8 @ 9,34 8АѴ "ВВЕДИТЕ" СОЬОК В-/И 

9 @ 11,24 ЗАѴ начальную дату: " СЕТ р4а(1 

10 @ 13,24 ЗАѴ конечную дату: " СЕТ р4а(2 

11 КЕАБ 

12 
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13 ІДО ВГ>1 

14 8ЕТ РІЬТЕК ТО ё_т > = рсіаіі АЫО. <1_г <= рхіаі2 

15 СО ТОР 

16 8ЕТ РІЕЬОЗ ТО 1ат,пат,сХс,гі_г 

17 СЬЕАК, 

18 

19 ІЮ Ѵ/НІЬЕ .Т. 

20 ? ■ Фамилия Имя а +; 

21 а Отчество Дата рождения* 

22 ОІЗРЬАѴ ОРРЫЕХТ5 

23 ? 

24 ШАГГ "Для продолжения вывода нажать любую клавишу." +; 

25 а Для прекращения вывода - клавишу Ѵ а ТО рѵ 

26 ? 

27 ІР ІІРРЕК(рѵ) = 'Ѵ* 

28 ЕХГГ 

29 ЕЫЭІР 

30 

31 ІР ЕОР() 

32 ЕХГГ 

33 ЕЬ8Е 

34 8КІР 

35 ЕЫОІР 

36 ЕЫОЕЮ 

37 

38 8ЕТ РІЬТЕК ТО 

39 ІІ8Е 

40 КЕТШШ 

Ввод и удаление данных в индексированных полях файла БД сопровождает¬ 
ся автоматической лереиндексацией записей. В результате чего на удаление 
неверных записей затрачивается время, пропорциональное емкости файла. 
Поэтому ввод данных в поля файла БД целесообразно выполнять не непосред¬ 
ственно, а через переменные, которые служат для промежуточного временного 
хранения. Данные, введенные в переменные, можно проверить и если они 
правильные, то ввести в файл БД, а если нет, то отказаться от ввода. Такая 
организация ввода уменьшает вероятность занесения в файл БД неверных 
данных. у 

Процедура Іпрігі организует ввод данных в файл БД через переменные. 
В начале процедуры выполняются команды установки состояний, подобно 
предыдущей процедуре. Команда БЕТ ЭЕѴІСЕ ТО 5С&ЕЕЫ устанавливает вывод 
сообщений на экран последующих выполняемых команд @...5АѴ. 

Далее определяются переменные, в которые будет вводиться марка 
автомобиля (ртаг), номерной знак (рп_г), состояние автомобиля (р$о&) и место 
его нахождения (рд_п) перед занесением в файл БД с именем ВР2. Длина 
переменных и тип должны совпадать с длиной и типом полей файла БД. В 
переменную заносится значение "Да”, которое будет использоваться для 
определения ответа пользователя. 

Ввод данных в переменные осуществляется командами @... СЕТ внутри 
цикла ЭО ѴѴНИЕ...ЕЫООО, который позволяет выполнить повторный ввод после 
ответа "Да" на вопрос "Редактировать данные ?". Ответ на этот вопрос можно 
ввести с клавиатуры, но лучше нажатием клавиши Пробел. Такой выбор 
реализуется с помощью использования функции @М (задание списка альтернатив¬ 
ных значений переменной) в шаблоне ввода-вывода переменной сіп. 

Если дан ответ "Нет", то осуществляется выход из цикла, очищается 21-я 
строка экрана и выполняется проверка того, ввел ли пользователь данные хотя 
бы в одну переменную. Если данные не вводились, то командой КЕТІІКЫ 
выполняется выход из программы. В противном случае управление передается 


335 



на блок процедуры, который снова высвечивает введенные в переменные 
данные. 

После команд @...<ЗЕТ, высвечивающих содержимое переменных, 
выполняется команда С1.ЕА& ОЕТЗ, которая деактивизирует эти команды и 
передает управление на следующую за ней команду @...ѲЕТ. В последней 
команде запрашивается разрешение на ввод данных из переменных в поля 
файла БД. Если команду С1.ЕА& ѲЕТ5 не поставить, все команды @...<ЗЕТ будут 
активизированы командой КЕАЭ, тогда как требуется активизировать только 
команду запроса на ввод в БД. При ответе на этот запрос в переменную сіп 
вводится значение "Да" или "Нет". 

Затем анализируется значение переменной сіп, и если оно равно "Да", то 
открывается файл БД и выполняется команда АРРЕЫЭ ВЬАЫК для ввода пустой 
записи в файл БД, а затем команда КЕКІ.АСЕ по замещению пустых полей этой 
записи данными из переменных. 

• Іприі.ргд 

1 СЬЕАК 

2 ЗЕТ ЕСНО ОРР 

3 ЗЕТ ТАЬК ОРР 

4 ЗЕТ ОЕѴІСЕ ТО ЗСКЕЕЫ 

5 

6 ршаг =5РАСЕ(10) 

7 рп_х =8РАСЕ(9) 

8 рсос-ЗРАСЕ(12) 

9 рв_п=ЗРАСЕ(12) 

10 с1п~="Дж • 

И 

12 @ 6,19 ТО 14,56 

13 

14 IX) ^ѴНІЬЕ <1п="Да" 

15 @ 7,21 ЗЛУ "Марка автомобиля " СЕТ ршаг 

16 @ 9,21 ЗАУ "Номерной знак " СЕТ рп_г 

17 @ 11,21 ЗАУ "Состояние автомобиля " СЕТ рао* 

18 @ 1321 ЗАУ "Где находится " СЕГ р*_п 

19 КЕАО 

20 @ 21,20 ЗАУ "Редактировать данные ? (Да/Нет) "; 

21 СЕТ 4п РІСТІЖЕ "@М Да,Нет" 

22 КЕАО 

23 ЕЫООО 

24 

25 @ 21,0 

26 

27 1Р ртаг =’ \ОК.рп_г=’ \ОК.р*о«=’ \ОК.рв_п =’ ' 

28 КЕТОКЫ 

29 ЕЫОІР 

30 

31 @ 721 $АУ "Марка автомобиля " СЕТ ртаг 

32 @ 9,21 ЗАУ "Номерной знак " СЕТ рп_г 

33 @ 11,21 ЗАУ "Состояние автомобиля " СЕТ раос 

34 @ 1321 ЗАУ "Где находится " СЕТ р*_п 

35 СЬЕАК СЕТЗ 

36 <& 21,15 ЗАУ "Сохранить данные в базе данных ? (Да/Нет) 

37 СЕТ <1п РІСТІЖЕ ’@М Да,Нет’ 

38 КЕАО 

39 

40 ІР 4п-’Да • 

41 і;зв В02 

42 АРРЕЫО В1АИК 

43 КЕРІАСЕ п_г \ѴГГН рп гдо» Ѵ/ГГН р*о*,; 
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таг ШГГН ртаг.дп ШГГН р^п 


45 ЕЫОІР 

46 

47 КЕТІЛМ 

Процедура Кеу иллюстрирует возможности назначения новых функций 
клавишам Р1-Р10. В этой процедуре функциональной клавише РЗ назначается 
вызов процедуры с именем ЗрізІат, реализующей вывод и просмотр списка 
фамилий водителей из файла БД ЕЮ1. Предварительно инициируется символьная 
переменная ріат и определяется окно для высвечивания списка фамилий. Далее 
открывается файл БД ЕЮ1 и устанавливается главный (управляющий ) индекс на 
поле фамилии іат. Затем командой @...5АѴ высвечивается предложение нажать 
клавишу РЗ для вывода списка фамилий. После того как нужная фамилия 
найдена, ее можно ввести в переменную ріат с помощью команды @...ОЕТ и 
использовать для поиска данных, например в файле перевозок, выполненных 
этим водителем. 

После нажатия клавиши РЗ вызывается процедура Зрізіат и на экране 
активизируется ранее определенное окно с именем Зрізіат. В этом окне 
командой 0І5РІ.АѴ А1_1_ высвечиваются фамилии, имена, отчества шести 
водителей. Следующая порция из этого списка выводится после нажатия любой 
клавиши (свойство команды РІ5РІ.АѴ). По достижении конца файла выполнение 
команды приостанавливается и высвечивается соответствующее сообщение. При 
нажатии любой клавиши командой РЕАСТІѴАТЕ ѴѴІЫООѴ/ удаляется окно Зрізіат 
и снова высвечивается сообщение о функции клавиши РЗ. Затем управление 
возвращается в строку, следующую после команды вызова процедуры Зрізіат. 

• Кеу.рг В 

1 ЗЕТ ЕСНО ОРР 

2 ЗЕТ ТАЬК ОРР 

3 ЗЕТ НЕЛОІЫС ОРР 

4 

5 рСат =5РАСЕ(15) 

6 ОЕРШЕ ЗрісГат РКОМ 10,12 ТО 18,65 СОЬОВ ВО+/В 

7 

8 ОЫ КЕУ ЬАВЕК. РЗ ІЮ ЗрііГат 

9 

10 ІІЗЕ ВОІ 

И ЗЕТ ОІШЕК ТО Гат 

12 

13 @ 21,20 5АѴ 'Просмотр списка водителей - клавиша РЗ' 

14 @ 5,12 ТО 7,65 

15 @ 6,16 ЗАУ 'Введите фамилию водителя - ' СЕТ рГат 

16 КЕАО 

17 • . . . 

18 • . . . 

19 • . . . 

20 КЕТОНЫ 

21 

22 РКОСЕОІЖЕ ЗрівСат 

23 @ 21,0 

24 АСТІѴАТЕ ШІЫЕЮѴ/ ЗрівГат 

25 ОІЗРЬАУ АЬЬ ОРР іат,пат,о(с 

26 ѴЛАГГ * ... Конец файла БД, нажмите любую клавишу ' 

27 ОЕАСТІѴАТЕ ШІЫЕЮШ ЗрівГаш 

28 @ 21,20 ЗАУ 'Просмотр списка водителей - клавиша РЗ* 

29 КЕТОКЫ 

Для пояснения функций управляющих клавиш и предоставления других 
данных о разработанной прикладной программе в ней обычно предусматривается 
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вывод справочной информации на экран нажатием одной из функциональных 
клавиш Р1-Р10 (обычно клавиши Р1). 

Процедура Неір.ргд иллюстрирует создание системы справочной информа¬ 
ции о выполнении некоторых операций в стандартных экранных формах ЕРІТ и 
ВКОѴѴ5Е. Для вызова этой информации в процедуре командой йЕРІЫЕ РОРІІР 
создается вертикальное меню с именем Р1, а командой йЕРІЫЕ ѴѴІЫйОѴѴ 
определяется окно с именем НІр, в котором будет высвечиваться справочная 
информация. 

Команда ОЫ БЕЬЕСТЮЫ определяет процедуру, которая будет выполняться 
при выборе позиций меню Р1. Затем функциональной клавише Р1 назначается 
выполнение процедуры НІр, которой передается значение параметра рЫр - 
число 1,2 или 3, определяющее соответственно высвечивание одного из трех 
экранов справочной информации. Первый экран - это информация о типах 
стандартных экранных форм Вгожзе и Есііі и меню Р1, второй - информация об 
управляющих клавишах формы Вгоѵѵзе, а третий - аналогичная информация о 
форме Есііі. 

Далее открывается файл базы данных В01, данные из которого будут 
высвечиваться в стандартной форме Вгожзе или Есііі, и активизируется меню Р1. 
В следующей строке закрывается файл БД и процедура завершается. Описанная 
часть представляет собой главную часть данной процедуры. Далее следуют 
вызываемые из нее процедуры. 

В процедуре Ргос_р1 для выполнения функций вертикального меню 
используется команда ОО СА5Е...ЕЫОСА5Е, в которой после опций СА5Е ВАК() 
= і (где і - номер позиции вертикального меню Р1) выполняется вывод данных 
в соответствующей стандартной экранной форме и присваивается требуемое 
значение переменной рЫр, которое используется при вызове процедуры НІр 
после нажатия функциональной клавиши Р1. В процедуре НІр сначала активизиру¬ 
ется окно НІр, затем в зависимости от значения переданного параметра рЫр 
осуществляется ветвление управления в команде ЭО СА5Е...ЕЫРСА5Е, после чего 
командой ТЕХТ...ЕЫОТЕХТ высвечивается текст справочной информации. Этот текст 
удерживается на экране благодаря приостановке выполнения программы 
последующей командой хх = ІЫКЕѴ(О). Если весь текст не умещается на одном 
экране, он разбивается на несколько частей. Ниже показан экран N 3 справочной 
информации. 


Кесогсіз Ріеісіз 6о То Ехіі 10:28:48 ат 


№М 

РАМ 

|ЫАМ |ОТС |о_К |$_к|кАТ 

АІІ 

і 


т т т т т 


МЕ 

і 

АрХ 



2 

Ста 

Экран помощи N3 Основные функциональные клавиши 


МЕ 

3 

Без 

- в форме ВК0Ѵ/5Е 

,с, 

МЕ 

4 

Бор 



МЕ 

5 

Ерм 

Р1 - вызов экрана помощи 

,А 

МЕ 

6 

Мал 

Р2 - переключение между Есііі и Вгомзе формой 

,с 

МЕ 

7 

Пол 

РІО - активизация меню 

,Е 

МЕ 

8 

Ков 

ЗНІРТ-Р2 - переход в экран создания запроса 


МЕ 

9 

Сад 

БНІРТ-Р8 - копирование содержимого поля из 


МЕ 

10 

Стр 

предыдущей записи в текущую 


МЕ 

11 

Бро 

5НІРТ-Р9 - распечатка содержимого файла БД 


МЕ 



ТАВ - движение по полям вправо 





ЗНІРТ-ТАВ - движение по полям влево 





Для продолжения просмотра нажмите любую клавишу ... 





1 і і ± ±. 




Вгоизе 10: \сІЬазе\сосі\В01 |Кес 1/11 |Рі1е | Ѵіеѵу апсі едН Ріеісіз 
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• Неір.ргз 

1 СЬЕАК 

2 ЗЕТ ЕСНО ОРР 

3 ЗЕТ ТАІЛС ОРР 

4 РИВЫС рЫр 

5 ОЕРІЫЕ Ѵ/ІЫЕЮѴ/ Нір РКОМ 4,9 ТО 18,69 ЫОЫЕ СОБОК ВО+/В 

6 

7 ОЕРІЫЕ РОРУР Р1 РКОМ 7,25 

8 ОЕРІЫЕ ВАК 1 ОР Р1 РКОМРТ " Е О I Т 

9 ОЕРІЫЕ ВАК 2 ОР Р1 РКОМРТ --• 5КІР 

10 ОЕРІЫЕ ВАК 3 ОР Р1 РКОМРТ • ВКОШ5Е 

11 ОЕРІЫЕ ВАК 4 ОР Р1 РКОМРТ ■-" 5КІР 

12 ОЕРІЫЕ ВАК 5 ОР Р1 РКОМРТ в Выход из программы а 

13 ОЫ ЗЕБЕСТІОЫ РОРУР Р1 ОО Ргос_р1 

14 

15 ОЫ КЕѴ ЬАВЕЬ Р1 ІЮ Нір ДѴІТН рЫр 

16 

17 ШЕ ВОІ 

18 рЫр=1 

19 АСТІѴАТЕ РОРУР Р1 

20 изЕ 

21 КЕТУКЫ 

22 

23 РКОСЕОІЖЕ Ргос рі 

24 ІЮ САЗЕ 

25 САЗЕ ВАК()=1 

26 рЫр =2 

27 ЕОІТ 

28 САЗЕ ВАК()=3 

29 рЫр =3 

30 ВКОШЗЕ 

31 САЗЕ ВАК()=5 

32 ОЕАСТІѴАТЕ РОРЫР 

33 ЕЫОСАЗЕ 

34 рЫр =1 

35 КЕТУКЫ 

36 

37 РКОСЕОУКЕ Нір 

38 РАКАМЕТЕК рЫр 

39 АСТГѴАТЕ ШІЫІЮШ Нір 

40 ІЮ САЗЕ 

41 САЗЕ рЫр-1 

42 ТЕХТ 

43 Экран помощи Ы1 Функции вертикального меню 


45 

46 

47 

48 

49 

50 

51 

52 

53 

54 

55 

56 

57 

58 


ЕОІТ- высвечивает на 
экране одновременно одну 
запись файла БД. Поля 
размещаются одно под 
другим в столбик. 


В К О >Ѵ 5 Е • выводит 
данные из файла БД в 
табличном виде. Строка таблицы - запись, колонка - поле. 

Выход из программы - завершение работы с программой. 

ЕЫОТЕХТ 

САЗЕ рЫр=2 


Формы представления данных 


ЕОІТ 


ВКОѴЗЕ 


Выход нз программы 
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59 ТЕХТ 

60 Экран помощи N2 Основные функциональные клавиши 

61 - в форме ЕОГТ 

62 

63 Р1 - вызов экрана помощи 

64 Р2 - переключение между Е<Ш и Вгочгкс формой 

65 РІО - активизация меню 

66 8НІРТ-Р2 - перевод в экран создания запроса 

67 8НІРТ-Р8 - копирование содержимого поля из предыдущей 

68 записи в текущую 

69 8НІРТ-Р9 - распечатка содержимого файла БД 

70 ТАВ - движение по полям вниз 

71 8НІРТ-ТАВ - движение по полям вверх 

72 

73 Продолжение - любая клавиша 

74 ВЫОТЕХТ 

75 хх=ІЫКЕѴ(0) 

76 сіеаг 

77 ТЕХТ 

78 НОМЕ - переход к первому полю 

79 ЕЫО - переход к последнему полю записи 

80 СТКІ-ЕИО - выход с сохранением 

81 Е8С - выход без сохранения 

82 

83 Для выхода из экрана помощи нажмите любую клавишу 

84 ЕЫОТЕХТ 

85 

86 СЛ8Е рЫр =3 

87 ТЕХТ 

88 Экран помощи N3 Основные функциональные клавиши 

89 - в форме ВКОАѴ8Е 

90 

91 Р1 - вызов экрана помощи 

92 Р2 - переключение между Е<Ш и Вгоѵве формой 

93 РІО - активизация меню 

94 8НІРТ-Р2 - переход в экран создания запроса 

95 8НІРТ-Р8 • копирование содержимого поля из предыдущей 

96 записи в текущую 

97 8НІРТ-Р9 - распечатка содержимого файла БД 

98 ТАВ - движение по полям вправо 

99 8НІРТ-ТАВ - движение по полям влево 

100 

101 Для продолжения просмотра нажмите любую клавишу 

102 ЕЫОТЕХТ 

103 хх*1ИКЕУ(0) 

104 СЬЕАК 

105 ТЕХТ 

106 НОМЕ - переход к первому полю 

107 ЕЫО * переход к последнему полю записи 

108 РСОЫ - переход по строкам и страницам 

109 РС11Р таблицы 

НО СТКЬ-ЕЫО - выход с сохранением 

111 Е8С - выход без сохранения 

112 

113 Для выхода из экрана помощи нажмите любую клавишу 

114 ЕЫОТЕХТ 

115 ЕЫОСА8Е Л . 

116хх=ШКЕѴ(0) 

117 ОЕАСТГѴАТЕ Ѵ/ІЫ009Ѵ Нір 

118 КЕТІЖЫ 
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В прикладных программах при выводе на печать часто приходится 
устанавливать параметры печати. Эти действия можно оформить в виде 
отдельной процедуры. Проиллюстрируем, как создать подобную процедуру на 
примере процедуры Мпиргіпі, позволяющей назначить параметры, которые 
высвечиваются на экране, как показано ниже. 


Формат страницы 


Параметры печати 


Отступ слева 

0 

Начать печать со страницы 

N 1 

Левая граница 

0 

Закончить на странице N 

9999 

Правая граница 

80 

Число копий 

1 

Абзац 

4 

Прогон бумаги 

И0ЫЕ 

Колич. строк на стр. 

66 

Хдать между страницами 

N 

Расст. между строками 

1 

Тип шрифта 

РІСА 



Качественная печать 

N 

I Для выхода 

нажмите клавишу Рдйп 



Установка параметров осуществляется посредством ввода значений в 
переменные, которые в дальнейшем присваиваются соответствующим системным 
переменным. 

В начале программы определяется окно, в котором будут высвечиваться 
параметры. Затем переменным присваиваются начальные значения, активизируется 
окно Мргіпі, в котором командами @...5АѴ и @...ОЕТ высвечиваются наименова¬ 
ния и начальные значения параметров. При установке курсора на поле в нижней 
строке окна с помощью опции МЕ55АОЕ команд @...ОЕТ высвечиваются 
сообщения о типе вводимого значения. В нижней строке окна командой @...$АѴ 
выводится информация для пользователя, как выйти из процедуры после ввода 
требуемых изменений или принятия высвеченных значений. 

Нажатие клавиши РдЭп означает переход к группе команд @...5АѴ и 
@...ОЕТ, располагаемых на следующей странице экрана, или при высвечивании 
только одной страницы - переход к следующей за командами @...5АѴ и 
@...ОЕТ команде КЕАЭ, которая записывает содержимое ОЕТ-полей в соответст¬ 
вующие переменные. Затем командой ОЕАСТІѴАТЕ ѴѴІЫРОѴ/ деактивизируется 
окно Мргіпі и системным переменным присваиваются значения из соответствую¬ 
щих переменных процедуры. Для удобства распознавания . переменных в 
процедуре им присваиваются те же имена, что и системным переменным, но 
без ведущих символов. 

* Мпиргіпі.ргд 

1 СЬЕАК 

2 8ЕТ ЕСНО ОРР 

3 8ЕТ ТАЬК ОРР 

4 8ЕТ 8ТАТІІ8 ОРР 

5 

6 ОЕРІЫЕ Мргіпі РВОМ 5,2 ТО 17,79 ЕЮІІВЬЕ СОЬОВ ВС+/Ь 

7 

8 тк^ пит = "Введите число" 

9 т*в_1одіс = "Введите У или И" 

10 тсв_сішт = "Для выбора опций нажмите клавишу <Пробел>" % 

11 ІоГГвеі = 0 

12 Ітаг^іп = 0 

13 гтаг^іп = 80 

14 ііиіеііі =■ 4 


341 





15 рІепвіЬ = 66 

16 СТОКЕ 1 ТО рсрасіпв* рЬра&е, рсоріес 

17 рера^е - 9999 

18 рфс( = -ЫОЫЕ " 

19 СТОКЕ .Р. ТО ратай, рциаШу 

20 ррйсЬ = "РІСА 

21 

22 АСТ ГѴ АТЕ ШІЫЕЮШ Мргіпі 

23 

24 @ 1,0 8АѴ КЕРЫСАТЕ ('-',76) 

25 @ 0,1 8АУ • Формат страницы а 

26 @ 3,1 8АУ " Отступ слева •; 

27 СЕТ ІоНсеІ РІСТИКЕ "99" МЕ88АСЕ ві{_пит 

28 @ 4,1 8АУ " Левая граница а ; 

29 СЕТ Ітаг^іп РІСТИКЕ "99" МЕ55АСЕ терпит 

30 @ 5,1 8АУ * Правая граница а ; 

31 СЕТ гтагвіп РІСТИКЕ "999" МЕ88АСЕ Ш5 В _пит 

32 @ 6,1 8АУ а Абзац а ; 

33 СЕТ іпсіспі РІСТИКЕ "99" МЕ88АСЕ т* 8 _пит 

34 @ 7,1 8АУ " Количество строк на странице а ; 

35 СЕТ рІепв'Ь РІСТИКЕ "99" МЕ88АСЕ т«в пит 

36 @ 8,1 8АУ " Расстояние между строками 

37 СЕТ рсрасіпв РІСТИКЕ "9" КАЫСЕ 13 МЕ88АСЕ терпит 

38 

39 @ 036 8АУ " Параметры печати " 

40 @ 336 8АУ " Начать печать со страницы N "; 

41 СЕТ рЬра 8 е РІСТИКЕ "999" МЕ88АСЕ т* в _пит 

42 @ 436 8АУ " Закончить на странице N 

43 СЕТ рераве РІСТИКЕ "9999" МЕ88АСЕ тер пит 

44 @ 536 8АУ " Число копий "; 

45 СЕТ рсоріес РІСТИКЕ "999" МЕ88АСЕ тер пит 

46 @ 636 8АУ " Прогон бумаги •; 

47 СЕТ реіесі РІСТИКЕ "@М ВЕРОКЕАРТЕК.ВОТН.МОЫЕ"; 

48 МЕ88АСЕ ті(_епит 

49 <§> 736 8АУ " Ждать между страницами "; 

50 СЕТ рѵай РІСТИКЕ "У" МЕ88АСЕ т« К _1о 8 іс 

51 @ 836 8АУ " Тип шрифта 

52 СЕТ ррйсЬ РІСТИКЕ "@М ^ЕРА^^Т,РIСА,Е^IТЕ,СОN^ЕN8Е^ , 

53 МЕ88АСЕ тс&_епит 

54 @ 936 8АѴ " Качественная печать "; 

55 СЕТ рчиаійу РІСТИКЕ "У" МЕ88АСЕ та* _Іо в іс 

56 КЕАИ 

57 

58 ИЕАСТІѴАТЕ ШШЕЮШ Мргіпі 

59 

60 _р1оГГсеІ = ІоНсеІ 

61 _1таг^іп = Ітаг^іп 

62 _гтаг^іп = гтаг^іп 

63 _іп<1епі = іпсіспі 

64 _р1еп^(Ь = рІепдіЬ 

65 _р$расіп{ = рсрасіпв 

66 _рЬра{е = рЬра^е 

67 рераве = рераве 

68 рсоріес = рсоріес 

69 _ре)есІ = реіесі 

70 _рѵай = рвгаіі 

71 _ррйсЬ = рріІсЬ 

72 _рциа1і(у = р^иаіііу 

73 КЕТИКЫ 
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Важной проблемой при разработке прикладных программ является 
обработка ошибочных ситуаций, которые могут возникнуть при их отладке и 
последующей эксплуатации. Такая обработка предполагает вывод как минимум 
информации о месте, в котором возникла такая ситуация. Часто можно также 
вывести информацию о характере ошибки и предложение выполнить действия, 
устраняющие ее. В случае неустранимости ошибочной ситуации целесообразно 
передать управление на завершение программы. Возможности по обработке 
ошибочных ситуаций можно продемонстрировать на примере процедуры 
Еггог.ргд, в которой обрабатываются три имитируемые ошибочные ситуации: 
вывод данных на принтер при его неготовности, поиск данных в неиндексирован- 
ном поле командой БЕЕК, которая используется только для индексированных 
полей, активизация несуществующего вертикального меню. 

В начале программы командой ЭЕРІЫЕ ѴЛЫЭОѴѴ определяется окно ѴѴегг, 
в котором будут высвечиваться сообщения об ошибках. Затем командой ОЫ 
ЕККОК устанавливается состояние, при котором ошибочная ситуация приводит к 
вызову процедуры ОіЬіЬка, обрабатывающей ошибочную ситуацию. Вместе с ней 
передается значение параметра, содержащее имя процедуры и номер строки, 
в которой возникла ошибка. Затем вызывается процедура БІТІІАС для имитации 
указанных выше ошибочных ситуаций. После выхода из ошибочной ситуации 
состояние ОЫ ЕГС&ОК выключается и главная процедура завершается. 

Дальше следуют тексты вызываемых процедур. В начале процедуры О&ЫЬка 
переменной регг присваивается текущее значение функции Е&&О&0 - номер 
ошибки. Затем активизируется окно ѴѴегг для высвечивания сообщения об 
ошибке и командой @...5АѴ в начале третьей строки окна выводится слово 
"Сообщение"', общее для всех сообщений об ошибках. Далее выполняется 
команда РО СА5Е...ЕЫОСА5Е, в которой управление разветвляется в зависимости 
от переданного в параметре регг номера ошибки и высвечиваются соответствую¬ 
щие сообщения. В начале каждого сообщения выводится имя процедуры и 
номер строки, в которой произошла ошибка. Эти данные передаются в 
процедуру как значение параметра рте$. Высвечиваемые командами сообщения 
удерживаются на экране командой ѴѴАІТ. 

Для продолжения выполнения программы нужно нажать любую клавишу. 
Сообщение об этом выводится командой 5ЕТ МЕ55АОЕ в нижней строке экрана. 
Команда 5ЕТ СОЫБОІ.Е ОРР подавляет вывод на экран любой информации, в 
том числе системного сообщения команды ѴѴАІТ, (кроме информации, 
выводимой командами @...5АѴ, системных сообщений об ошибках и предупреж¬ 
дений о перезаписи и удалении файлов). При нажатии любой клавиши после 
приостановки выполнения командой ѴѴАІТ, команда 5ЕТ СОЫ$ОІ_Е ОЫ 
восстанавливает вывод на экран системной информации, а команда БЕТ 
МЕББАѲЕ ТО удаляет высвеченное ранее сообщение в нижней строке экрана. 
Затем деактивизируется окно \Л/егг и управление возвращается в главную 
процедуру. Ниже показано окно при выводе сообщения об ошибке, возникшей 
при выводе на принтер. 


Ошибка в процедуре 51 ТІІАС . Строка ^ 52 

Сообщение: Принтер не готов ! 

Включите принтер (если он не включен) 
и переведите его в состояние ОИ ПНЕ. 


В процедуре Бііиас командой БЕТ ЭЕѴІСЕ ТО РКІЫТЕК устанавливается 
вывод сообщений команд @...БАѴ на принтер, что при неготовности принтера 





(не включенном в сеть или находящемся в состоянии ОРР ЫЫЕ) вызывает 
ошибку с номером 125. После обработки ошибочной ситуации и установки 
принтера в состояние ОЫ ЫЫЕ управление передается на команду ЗЕТ РЕѴІСЕ 
ТО 5С&ЕЕЫ, которая восстанавливает вывод сообщений команд @...5АѴ на экран. 

Для получения ошибки с номером 26 открывается файл БД ЕЮ1 и не 
устанавливается управляющий индекс. Выполнение команды ЗЕЕК поиска данных 
по неиндексированному полю приводит к ошибочной ситуации. После обработки 
этой ситуации командой ІІЗЕ выполняется закрытие файла БД. 

Команда АСТІѴАТЕ РОРЫР Рр вызывает ошибку с номером 165, если 
вертикального меню с именем Рр в текущем директории не существует. 

• Еггог.ргд 

1 СЬЕЛК 

2 8ЕТ ЕСНО ОРР 

3 8ЕТ ТАИС ОРР 

4 ОЕРІЫЕ Ш1ЫЕЮШ Ѵ/сгт РКОМ 6,13 ТО 15,66 СОІХЖ СВ+/К 

5 

6 ОМ ЕК.КОК ЕЮ ОсЬіЬка \ѴГГН 'Ошибка в процедуре ЧРКОСКАМ()+; 

7 \ Строка Ы: ’+І.ТКІМ(8ТК(ІЛЫЕ())) 

8 

9 ЕЮ 8і(иас 

10 

11 ОЫ ЕККОК 

12 КЕТІІКЫ 

13 

14 РКОСЕОІЖЕ ОсЬіЬка 

15 РАКАМЕТЕК рте® 

16 регг =ЕКЕОК() 

17 АСТІѴАТЕ ШІЫЕЮѴ/ ѵегг 

18 @ 32 8АѴ "Сообщение:” соіог ѵ +/г 

19 

20 ІЮ СА8Е 

21 СА8Е регг * 26 

22 @ 12 8АѴ рте* 

23 @ 3,14 8АѴ "Файл БД не проиндексирован ! " 

24 @ 4,14 8АѴ "Откройте индексный файл. " 

25 

26 . . . 

27 . . . 

28 . . . 

29 

30 СА5Е регг = 125 

31 @ 12 8АѴ рте* 

32 @ 3,14 8АѴ "Принтер не готов ! ■ 

33 <§> 4,14 8АѴ "Включите принтер (если он не включен)" 

34 @ 5,14 8АѴ "и переведите его в состояние ОЫ ЕЛЫЕ." 

35 СА8Е регг = 165 

36 @12 8АУ рте* 

37 @ 3,14 8АУ "Вертикальное меню не определено ! " 

38 @ 4,14 8АУ "Вы должны определить меню перед " 

39 @ 5,14 8АУ "активизацией или определением его " 

40 @ 6,14 8АУ "позиций. " 

41 ЕЫІЗСА8Е 

42 

43 8ЕТ МЕ88АСЕ ТО "... для продолжения нажмите любую клавишу" 

44 8ЕТ С0И80І.Е ОРР 

45 ѴѴАГГ 

46 8ЕТ С0Ы80ЬЕ ОЫ 

47 8ЕТ МЕ88АСЕ ТО 
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48 ОЕАСТІѴАТЕ ШІЫІЮШ Ѵ/сгг 

49 КЕТШМ 

50 

51 РКОСЕОІЛШ 8і(иас 

52 8ЕТ ОЕѴІСЕ ТО РКІЫТЕК 

53 8ЕТ ОЕѴІСЕ ТО 8СКЕЕЫ 

54 

-55І18Е ВЭ1 

56 8ЕЕК Т 

57 118Б 

58 

59 АСТІѴАТВ РОРЫР Рр 

60 кетіжы 

Ввод и обновление данных в файлах БД является важной составной частью 
эксплуатации прикладной программы. В гл. 2 рассматривалась задача учета 
перевозок автотранспортным предприятием. 

Данные в этой задаче представлены в виде четырех связанных файлов БД. 
Ключевой из них - файл вЬі, содержащий сведения о водителях (фамилию, 
имя, отчество, номерной знак автомобиля, на котором работает и т.д.). Данные 
о выполненных водителями перевозках содержатся в файле ВОЗ, который связан 
с файлом В01 по общему полю номерного знака. 

При вводе данных о перевозках нужно сначала найти фамилию водителя 
в файле В01, затем перейти в файл ВОЗ, по номерному знаку его автомобиля 
найти ранее введенные записи о перевозках и добавить новую запись. 

Процедура АррепсІ реализует эти операции по вводу новых записей о 
перевозках. В верхней части экранной формы этой процедуры, показанной ниже, 
высвечиваются данные из файла БД В01, содержащего сведения о водителях, 
а в нижней - данные из файла БД перевозок ВРЗ. Пользователь, выбрав 
фамилию, нажимает клавишу Е$с и переходит к заполнению информации по 
перевозкам грузов, выполненных данным водителем. 


8:20:40рт 

09-33 МИД 

01-34 МИД 

34-56 МИД 

Бронзов 

Старченко 

Строков 

Сергей 

Сергей 

Олег 

Васильевич 

Николаевич 

Валерьевич 


Груз Вес Откуда Куда Выезд Прибытие Время Горю¬ 

чее 


Станки ЧПУ 

3.0 

Одинцово 

Г орький 

24/03/89 

25/03/89 

14 

44.00 

Мебель 

1.0 

Москва 

Калуга 

30/06/89 

01/07/89 

12 

46.00 

Двигатели 

3.0 

Москва 

Рязань 

12/10/89 

14/10/89 

22 

72.00 


Переход к водителям - <СТК1_-ЕН0>. Выход из программы - Р8 
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Процедура начинается с определения двух окон \ЛИ и \Ѵ2 для высвечива¬ 
ния данных из файлов БД В01 и ЕЮЗ. Затем клавише Р8 назначается функция 
завершения процедуры командой ЯЕТІІКЫ. Команда ЗЕЬЕСТ 1 активизирует 
рабочую область 1, в которой последующей командой открывается файл БД ЕЮ1 
с управляющим индексом в поле Іат. Этому файлу назначается алиас А, 
который в дальнейшем можно использовать для обращения к его полям, если 
рабочая область не активна. Командой 5Е1.ЕСТ 2 активизируется рабочая область 
2, в которой открывается файл БД ЕЮЗ и ему назначается алиас В. Следующей 
командой 5ЕІ.ЕСТ 1 выбирается (активизируется) рабочая область 1 и открывается 
цикл ОО ѴѴНИ.Е...ЕЫООО, в котором и выполняются все операции по вводу 
данных о перевозках. 

В этом цикле сначала а 22-й строке экрана командой @...5АѴ высвечивает¬ 
ся текст сообщения с предложением выбрать фамилию и функции клавиш Е&с 
и Р8. Затем выводятся данные из файла ВЭ1 в окне Ѵ/1 в стандартной форме 
Вгоѵѵзе. В команде В&ОѴѴЗЕ ширина выводимого поля п .2 ограничивается 22 
позициями и все поля, кроме поля Еат, опцией Р&ЕЕ2Е закрываются для 
редактирования (курсор не может перемещаться в эти поля). 

После выбора фамилии и выхода из формы Вгоѵѵзе командой @ 22,0 
очищается 22-я строка экрана и переменной ѵп _2 присваивается значение поля 
п .2 файла ВР1 (впереди поля стоит алиас этого файла). Заметим, что алиас в 
данном случае ставить не обязательно, так как в текущий момент активизирована 
рабочая область именно этого файла. Затем выбирается рабочая область 2 и в 
ней устанавливается фильтр на отбор записей с номерным знаком, взятым из 
переменной ѵп_ 2 . После отбора этих записей командой АРРЕЫй ВЬАЫК в конец 
добавляется пустая запись и затем командой &ЕРІ.АСЕ значение поля п .2 
замещается значением переменной ѵп. 2 . Следующая за ней команда ЗЕТ 

САККѴ ТО п_ 2 обеспечивает автоматический перенос значения поля п _2 из 

предыдущей записи в новую добавляемую запись. 

Затем командой @...ЗАѴ высвечивается сообщение с именами клавиш, 
используемых для перехода из нижней части экрана (файл перевозок) в 
верхнюю часть экрана (файл данных о водителях) выводится шапка таблицы 
Вгоѵѵзе файла ЕЮЗ и выполняется собственно команда вывода данных в эту 
таблицу. После выхода из таблицы Вгоѵѵзе клавишами СТгІ-Епсі очищаются строки 
экрана (10,11 и 22), снимается фильтр, выбирается рабочая область 1 и 
осуществляется переход на следующую запись в файле ВЭ1. 

• АррепсІ.ргв 

1 СЬЕАК 

2 8ЕТ ВЕ1Х ОРР 

3 5ЕТ ТА1ЛС ОРР 

4 5ЕТ ЕСНО ОРР 

5 ЗЕТ 5ТАТ113 ОРР 

6 

7 ОЕРІЫЕ 1ѴІЫООДѴ >Ѵ1 РВОМ 1,0 ТО 5,79 ИОЫЕ СОЬОВ >Ѵ/В,ОВ+/В, В/В 

8 ЭЕРШЕ \Ѵ2 РВОМ 12,0 ТО 20,79 ЫОЫЕ СОЬОВ Н/ВС,СВ+/В,ВО/ВС 

9 ОЫ КЕѴ ЬАВЕЬ Р8 ВЕПЖЫ 

10 

11 ЗЕЬЕСТ 1 

12 ЫЗЕ ВОІ ОІШЕК Іат АЬІАЗ А 

13 ЗЕЬЕСТ 2 

14 ШЕ ВОЗ АЬІАЗ В 

15 

16 ЗЕЬЕСТ 1 

17 ОО ДѴНІЬЕ .Т. 

18 

19 @ 22,1 ЗЛУ "Выберите фамилию и нажмите клавишу" +; 

20 " <Е5С>. Выход из программы - Р8" СОЬОК 0+/Ы 


346 



21 ВКОѴ8Е РІЕІ.08 п_г/22,Гат,пат,оіс СОМРКЕ88 ЫСХХЕАК; 

22 ѴІЫЕЮѴ/ VI РКЕЕ2Е (ат 

23 @ 22,0 

24 ѵп _2 =А- >п _2 

25 

26 8ЕІ~ЕСТ 2 

27 8ЕТ РІЬТЕК ТО п_г =ѵп_х 

28 АРРЕЫОВЬАЫК 

29 КЕРЬАСЕ п _2 ѴГГН ѵп _2 

30 8ЕТ САККѴ ТО п_г 

31 

32 @ 22$ 8АѴ " Переход к данным о водителях - <СТКЬ-ЕМО>. а +; 

33 а Выход из программы - Р8 * СОЬОК. С+/Ы 

34 @ 10,0 8АѴ " Груз Вес Откуда Куда *+; 

35 а Выезд Прибытие Время Горнъ а 

36 @ 11,59 8АѴ а нее 

37 ВКОѴ8Е РІЕЬ08 п_в/14,ѵев,о_р/8Д_с1/9,<1_ѵ,<1_р,ѵгт/4,гвг,п_2; 

38 СОМРКЕ88 ѴІЫООѴ Ѵ2 ЫОМЕЫЦ 

39 @ 10,0 

40 @ 11,0 

41 @ 22,0 

42 8ЕТ РН-ТЕК ТО 

43 5ЕГЕСТ 1 

44 5КІР 

45 

46 ЕЫОЕЮ 

47 КЕТІШЫ 

Эксплуатация прикладных программ пользователем обычно осуществляется 
с помощью систем меню, которые можно представить в различном виде. 
Однако практика показывает, что наиболее употребительными являются меню 
горизонтального и вертикального типов и их комбинации. Своего рода 
стандартом стала форма меню, состоящая из главного горизонтального меню, 
к позициям которого прикрепляются вертикальные меню нескольких уровней. 
Создание такого типа меню иллюстрирует процедура Мели, в которой 
горизонтальное меню состоит из трех позиций, размещаемых в верхней части 
экрана. К первым двум позициям прикрепляются вертикальные меню. Вертикаль¬ 
ное меню, прикрепленное к первой позиции, - одноуровневое, а ко второй 
позиции - двухуровневое. Третья позиция горизонтального меню является 
исполнимой и в ней нет уровней. Эта система меню показана ниже. 


Водители 

Стах работы - больше 5 лет 
Категории А,В,С 


Автомобили Выход 

В автопарке | 

В рейсе 

1 

На заводе 

В ремонте 

На автопредприятии 



Процедура начинается с команды чистки экрана СІ.ЕА&. Затем командой 
ЭЕРІЫЕ МЕЫ1) определяется горизонтальное меню с именем От и командами 
ЭЕРІЫЕ РАЭ тексты его позиций с именами Р1, Р2 и РЗ. Команда ОЫ РАЭ 
обеспечивает активизацию вертикального меню с именем Ррі после выбора 
позиции Р1 горизонтального меню. Команда ОЫ 5ЕІ.ЕСТІОЫ обеспечивает вызов 
процедуры Ргос2 после выбора позиции Р2 горизонтального меню. В этой 
процедуре активизируется вертикальное меню второго уровня. Следующая 
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команда ОЫ ЗЕІ.ЕСТІОЫ назначает выполнение команды &ЕТІЖЫ при выборе 
позиции РЗ горизонтального меню. 

Дальше размещаются команды, определяющие вертикальные меню Ррі, 
Рр2 и РрЗ. Тексты позиций этих меню назначаются командами ЭЕРІЫЕ ВАР і, 
где і - номер позиции. После команд определения текста позиций следует 
команда ОЫ ЗЕЬЕСТЮЫ РОРІІР, которая устанавливает вызов процедур 
Ргос_рр1, Ргос_рр2 и Ргос_ррЗ, реализующих функции соответствующих 
вертикальных меню. Затем командой АСТІѴАТЕ МЕЫІІ активизируется горизон¬ 
тальное меню От и командой ВЕТІІРЫ завершается главная процедура, ниже 
которой размещаются процедуры, вызываемые при выборе позиций меню. В 
этих процедурах используется команда ЭО СА5Е...ЕЫОСА5Е для разветвления 
управления в зависимости от номера выбранной активной позиции меню. Этот 
номер передается с помощью функции ВА&(). Неактивные позиции, в которых 
задается опция 5КІР, служат для рисования отделяющих горизонтальных линий, 
информационного текста и т.д. 


* Мепи.рг& 

1 СХЕАК 

2 ОЕРШЕ МЕ1Ч11 Сш 

3 ОЕРШЕ РАО Р1 ОР От РКОМРТ " Водители • АТ 0,1 

4 ОЕРШЕ РАО Р2 ОР От РКОМРТ ■ Автомобили " ЛТ 0,20 

5 ОЕРШЕ РАО РЗ ОР От РКОМРТ * Выход - ЛТ 0,40 

6 

7 ОЫ РАО Р1 ОР СМ АСТІѴАТЕ РОРІІР Ррі 

8 ОЫ ЗЕЬЕСТІОИ РАО Р2 ОР Сш АСТІѴАТЕ РОРІІР Рр2 

9 ОЫ ЗЕЬЕСТЮИ РАО РЗ ОР Сш КЕШКИ 

10 

11 ОЕРШЕ РОРІІР Ррі РКОМ 3,1 

12 ОЕРШЕ ВАК 1 ОР Ррі РКОМРТ * Стаж работы - больше 5 лет- 

13 ОЕРШЕ ВАК 2 ОР Ррі РКОМРТ "•-* 5КІР 

14 ОЕРШЕ ВАК 3 ОР Ррі РКОМРТ • Категории А, В, С 

15 ОЫ 5ЕЕЕСТІОН РОРІІР Ррі ПО Ргосррі 

16 

17 ОЕРШЕ РОРІІР Рр2 РКОМ 3,21 

18 ОЕРШЕ ВАК 1 ОР Рр2 РКОМРТ * В автопарке ■ 

19 ОЕРШЕ ВАК 2 ОР Рр2 РКОМРТ --■ 5КІР 

20 ОЕРШЕ ВАК 3 ОР Рр2 РКОМРТ ■ В рейсе 

21 ОЕРШЕ ВАК 4 ОР Рр2 РКОМРТ --■ 8КІР 

22 ОЕРШЕ ВАК 5 ОР Рр2 РКОМРТ " В ремонте 

23 ОЫ ЗЕЬЕСТЮЫ РОРІІР Рр2 ОО Ргос рр2 

24 

25 ОЕРШЕ РОРЫР Рр23 РКОМ 6,34 

26 ОЕРШЕ ВАК 1 ОР Рр23 РКОМРТ ■ На заводе 

27 ОЕРШЕ ВАК 2 ОР Рр23 РКОМРТ "■-" 5КІР 

28 ОЕРШЕ ВАК 3 ОР Рр23 РКОМРТ " На автопредприятин ■ 

29 ОЫ ЗЕЬЕСТІОН РОРІІР Рр23 ОО Ргос_рр23 

30 

31 АСТІѴАТЕ МЕНІІ Сю 

32 

33 КЕШКИ 

34 

35 

36 РКОСЕОІІКЕ Ргос ррі 

37 ОО СА5Е 

38 СА5ЕВАК()=1 

39 • . . . 

40 СЛ8Е ВАК()=3 
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41 • . . . 

42 ЕЫЕГСАЗЕ 

43 

44 КЕТІЖЫ 

45 

46 РКОСЕОІЖЕ Ргос_рр2 

47 ІЮ СА5Е 

48 СА8Е ВАК()=1 

49 • ... 

50 САЗЕ ВАК()=3 

51 • . . . 

52 СА8ЕВАК()=5 

53 АСТІѴАТЕ РОР11Р Рр23 

54 ЕЫІЮАЗЕ 

55 КЕТІЖЫ 

56 

57 РКОСЕОІЖЕ Ргос_рр23 

58 ІЮ САЗЕ 

59 САЗЕ ВАКО-1 

60 • . . . 

61 САЗЕ ВАКО-3 

62 * . . . 

63 ЕЫЭСАЗЕ 

64 КЕТІЖЫ 

65 

66 РКОСЕОІЖЕ Ргос2 

67 АСТІѴАТЕ РОРІЖ Рр2 

68 КЕТІЖЫ 

В следующей процедуре Мизіс демонстрируются возможности по 
озвучиванию прикладных программ. Озвучивание выполнения различных операций 
в прикладной программе создает удобство при эксплуатации. 

В процедуре Мизіс моделируется звучание нот в диапазоне от "до" до 
"си" при нажатии цифровых клавиш верхнего ряда клавиатуры от 1 до знака 
" = ", которым на экране, показанном ниже, соответствуют клавиши музыкального 
инструмента. 

При нажатии клавиши клавиатуры компьютера красным цветом на экране 
подсвечивается соответствующая клавиша музыкального инструмента. 



Для завершения нажмите клавишу <Пробел> 


Процедура Мизіс начинается с определения окна с именем КеуЬ, в 
котором будут высвечиваться клавиши музыкального инструмента. Затем 
командой @...$АѴ в 20-й строке экрана выводится сообщение о клавише, 
управляющей выходом из процедуры. Далее активизируется окно КеуЬ, в 
котором высвечиваются клавиши музыкального инструмента. Моделирование 
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звучания клавиш выполняется в цикле ЭО Ѵ/НИЕ...ЕЫООО. В этом цикле сначала 
командой 5ЕТ СОЫЗОІ-Е ОРР подавляется вывод на экран сообщения, которое 
высвечивается при выполнении последующей команды ѴѴАІТ. Эта команда 
приостанавливает выполнение программы до нажатия любой клавиши. Последняя 
нажатая клавиша анализируется с помощью функции І_А5ТКЕѴ() в главной 
процедуре. Если это "Пробел", то осуществляется выход из цикла, после чего 
деактивизируется окно КеуЬ, очищается 20-я строка экрана, и командой 5ЕТ ВЕІ_!_ 
ТО восстанавливается частота и длительность звукового сигнала, принятые по 
умолчанию, и главная процедура завершается командой КЕШКИ. В противном 
случае вызывается процедура МеІосІ. После возвращения из этой процедуры 
продолжается выполнение цикла ЭО ѴѴН ИЕ...ЕЫРОО. 

В процедуре МеІосі в соответствии с нажатой клавишей верхнего ряда 
клавиатуры моделируется звучание определенной ноты. После этого и в случае, 
если нажата клавиша, отличная от упомянутых клавиш верхнего ряда клавиатуры, 
управление возвращается в главную процедуру. 

Процедура МеІосі содержит команду ЭО СА5Е...ЕИЭСА5Е, в которой 
управление разветвляется в зависимости от нажатой клавиши, возвращаемой 
функцией І.А5ТКЕѴ(). После опции СА5Е переменным і и к присваиваются 
частота звучания и номер колонки на экране, в которой расположена левая 
сторона клавиши музыкального инструмента. Эти клавиши разделяются на 
четыре типа: левая, средняя, правая и диез/бемоль (черного цвета). Левая 
клавиша расположена слева от клавиши диез/бемоль, правая - справа от такой 
клавиши, а средняя - между этими клавишами. В зависимости от типа клавиши 
вызываются процедуры КІеѵО, КзгесІО, КргаѵО и ЭіЬетоІО для подсветки красным 
цветом соответствующей клавиши, и процедуры КІеѵІ, Кзгесіі, Кргаѵі и ОіЬетоІІ 
для восстановления первоначального цвета. 

Процедура 2ѵик вызывает звуковой сигнал с частотой, соответствующей 
нажатой клавише, передаваемой в параметре і. Эта частота устанавливается 
командой 5ЕТ ВЕ1_1_. 


• Михіс.ргв 

1 ЗЕТ ЕСНО ОРР 

2 ЗЕТ ТА НС ОРР 

3 ЗЕТ СТАТІЮ ОРР 

4 ЗЕТ Е5САРЕ ОЫ 

5 

6 БЕР^Е \ѴІЫЕЮ\Ѵ КеуЬ РВОМ 4,23 ТО 14,53 ЫОЫЕ СОЬОК О/О 

7 


8 @ 20,19 ЗАУ "Для завершения нажмите клавишу <Пробел>" 


9 АСТІѴАТЕ \ѴтЕЮ\Ѵ КеуЬ 

10 @ 1,1 5АѴ " 

11 @ 2,1 5АѴ " 

12 @ 3,1 5АѴ " 

13 @ 4,1 5АѴ “ 

14 @ 5,1 ЗАУ " 

15 @ 6,1 ЗАУ " 

16 @ 7,1 ЗАУ " 

17 @ 8,1 ЗАУ " 

18 @ 9,1 ЗАУ " 

19 

20 ОО ХѴНІЬЕ Т. 21 

22 ЗЕТ СОЫЗОЬЕ ОРР 

23 Ѵ/АГГ 

24 ЗЕТ СХЖЗОЬЕ ОЫ 

25 

26 ІР ЬАЗТКЕУО = 32 



"СОЬОК 

■ соиж 
" сошк 
•соьок 
•соьок 
"соьок 
"соьок 
• союк 
" соьок. 


ВО+/В 

ВО+/В 

ВС+/В 

ВО+/В 

ВО+/В 

ВО+/В 

ВО+/В 

ВО+/В 

ВО+/В 
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27 ЕХГТ 

28 ЕЫОІР 

29 ІЮ Мсісхі 

30 

31 ЕЫОЕЮ 

32 

33 ОЕАСТІѴАТЕ ѴѴІЫЕЮѴѴ КсуЬ 

34 @ 20,0 

35 8ЕТ ВЕІХ ТО 

36 КЕТОНЫ 

37 

38 РКОСЕОІЖЕ Мсісхі 

39 ЕЮ СА8Е 

40 СА8Е ЬА5ТКЕѴ() = 49 

41 і=523 

42 к =2 

43 ІЮ КІсѵО ѴѴГГН к 

44 ІЮ 2ѵик ѴѴГГН і 

45 ІЮ Кісѵі ѴѴГГН к 

46 СА8Е ЕА8ТКЕѴ() = 50 

47 і=552 

48 к =4 

49 ЕЮ ОіЬстоЮ ѴѴГГН к 

50 ЕЮ 2ѵик 1ѴГГН і 

51 ЕЮ ОіЬетоІІ ѴѴГГН к 

52 СА8Е ЬА8ТКЕѴ() = 51 

53 і=587 

54 к =7 

55 ЕЮ КсгеЛО ѴѴГГН к 

56 ЕЮ 2ѵик ѴѴГГН і 

57 ІЮ КсгесІІ ѴѴІТН к 

58 СА8Е ЕА8ТКЕѴ() = 52 

59 і =612 

60 к =8 

61 ЕЮ ОіЬстоЮ ѴѴІТН к 

62 ЕЮ Хѵик ѴѴГГН і 

63 ЕЮ ОіЬетоІІ ѴѴІТН к 

64 СА8Е ЬА8ТКЕУ() = 53 

65 і=659 

66 к =11 

67 ЕЮ КргаѵО ѴѴГГН к 

68 ЕЮ 2ѵик ѴѴГГН і 

69 ЕЮ Кргаѵі ѴѴГГН к 

70 СА8Е ЕА8ТКЕѴ() = 54 

71 і=698 

72 к =14 

73 ЕЮ КІсѵО ѴѴГГН к 

74 ЕЮ 2ѵик ѴѴГГН і 

75 ЕЮ Кісѵі ѴѴГГН к 

76 СА8Е ЬА8ТКЕѴ() = 55 

77 і=743 

78 к =16 

79 ЕЮ ОіЬстоЮ ѴѴГГН к 

80 ЕЮ 2ѵик ѴѴГГН і 

81 ЕЮ ОіЬетоІІ ѴѴІТН к 

82 СА8Е ЕА8ТКЕѴ() = 56 

83 і =784 

84 к =19 

85 ЕЮ КжгесЮ ѴѴГГН к 


АА "Г 


АА “2“ 


АА -3- 


АА -4" 


АА -5 е 


АА -6" 


АА -7- 


АА я & л 
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86 ЕЮ 2ѵик ѴІТН і 

87 ЕЮ Кігесіі ѴГГН к 

88 СА8Е ЬАЗТКЕѴО ” 57 АА "9" 

89 і-832 

90 к -20 

91 ЕЮ ОіЬетоІО Ѵ/ГГН к 

92 ЕЮ 2ѵик ШГГН і 

93 ЕЮ ОіЬетоІІ ѴѴГГН к 

94 СА5Е ЕА5ТКЕУ() - 48 АА "0” 

95 і =880 

96 к -23 

97 ЕЮ КігоЮ Ѵ/ГГН к 

98 ІЮ 2ѵик ѴГГН і 

99 ІЮ К«гс41 ШГГН к 

100 СА8В ЕА$ТКЕѴ() = 45 АА в в 

101 і =931 

102 к -24 

103 ЕЮ ОіЬетоІО Ѵ/ГГН к 

104 ЕЮ 2ѵик \ѴГГН і 

105 ІЮ ОіЬетоІІ Ѵ/ГГН к 

106 СА8Е ЬА8ТКЕУ() - 61 АА “=“ 

107 і =980 

108 к -27 

109 ЕЮ КргаѵО ѴѴГГН к 

НО ЕЮ 2ѵик Ѵ/ГГН і 

111 ЕЮ Кргжѵі Ѵ/ГГН к 

112 ЕИЕЮАЗВ 

113 КЕТ1ЖЫ 

114 

115 РКОСЕОІЖЕ 2ѵик 

116 РАКАМЕТЕК і 

117 5ЕТ ВЕІХ ТО І,1 

118 7 СНК(7) 

119 КЕТ1ЖЫ 

120 

121 РКОСЕОІЖЕ КІсѵО 

122 РАКАМЕТЕК к 

123 @ 2Х ЗАУ " - СОІХЖ СК+/К 

124 @ 3,к 8АУ • - СОІХЖ СК+/Е 

125 @ ЛХ ЗАУ * ■ СОІХЖ СК+/& 
126@5Д8АУ • СОЬОК СК+/К 

127 @ 6Х ЗАУ " • СОЬОК СК+/К 

128 @ IX ЗАУ ■ • СОШК СК +/К 

129 @ 8* ЗАУ • ' СОІХЖ СЕ+/К 

130 КЕТ1ЖЫ 

131 

132 РКОСЕОІЖЕ Кіеѵі 

133 РАНА МЕТЕК к 

134 @ 2Х ЗА У * " СОІХЖ ВО+/В 

135 @ ЗХ ЗАУ ■ • СОШК ВО+/В 

136 @ 4Х ЗАУ " ■ СОІХЖ ВО+/В 

137 @ 5Х ЗАУ " • СОІХЖ ВО+/В 

138 @ 6Х ЗАУ " * СОІХЖ ВО+/В 

139 @ IX ЗАУ " ■ СОІХЖ ВО+/В 

140 ® &Х ЗАУ ■ * СОСОК ВО +/В 

141 КЕТІЖЫ 

142 

143 РКОСЕОІЖЕ КбгеаО 

144 ГАКА МЕТЕК к 
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*45 @2Х 5АѴ ■' СОІХЖ СВ+/В 

146 <$ЗХ $ЛѴ •* СОІХЖ СК+/Я 

147 @ 4,к 5АУ "" СОІХЖ СВ+/В 

148 @ 5Х 8АѴ ■" СОІХЖ СВ+/В 

149 @ бук 8АУ *• СОІХЖ ОК.+/К. 

150 @ 7Х-1 5АУ " ■ СОІХЖ СВ+/В 

151 @ 8*1 5АУ ' " СОІХЖ СВ+/В 

152 ВЕТУВИ 

153 

154 РВОСЕОУВЕ КсгеЛІ 

155 РАВАМЕТЕВ к 

156 @ 2* 8АѴ •• СОІХЖ ВС+/В 

157 @ 3* 8АѴ * " СОІХЖ ВС+/В 

158 @ 4* ЗАѴ " " СОІХЖ ВС+/В 

159 @ 5* 8АѴ " " СОІХЖ ВС+/В 

160 @ 6Х 5АѴ * " СОЬОВ ВС + /В 

161 @ 7*-1 8АѴ “ " СОЬОВ ВС+/В 

162 @ 8*-1 8АУ " “ СОІХЖ ВС+/В 

163 ВЕТУВЫ 

164 

165 РВОСЕОУВЕ КргаѵО 

166 РАВАМЕТЕВ к 

167 @2* 5АУ " * СОІХЖ СВ+/В 

168 @3* 5АУ ■ * СОІХЖ СВ+/К 

169 @4* 5АѴ ' • СОІХЖ СВ+/В 

170 @5* 5АУ " - СОІХЖ СВ+/В 

171 @ 6* 8АУ “ " СОІХЖ СВ+/В 

172 @ 7*-1 8АУ “ • СОІХЖ СВ+/В 

173 @ 8*1 8АУ " • СОІХЖ СВ +/В 

174 ВЕТЫВИ 

175 

176 РВОСЕОУВЕ Кргаѵі 

177 РАВАМЕТЕВ к 

178 @ 2*'5АУ " " СОІХЖ ВС+/В 

179 @ 3* $АУ " ' СОШВ ВС +/В 

180 @ 4Х 5АѴ * " СОІХЖ ВС+/В 

181 @ 5Х 5АУ " " СОІХЖ ВС+/В 

182 @ 6Х 5АУ • • СОІХЖ ВС+/В 

183 @ 7*1 5АУ " " СОІХЖ ВС+/В 

184 @ 8*-1 ЗАУ ■ " СОІХЖ ВС+/В 

185 ВЕТУВЫ 

186 

187 РВОСЕОУВЕ ОіЬстоЮ 

188 РАВАМЕТЕ В к 

189 @ 2,К ЗАУ 4Н" СОІХЖ СВ+/В 

190 @ 3,К ЗАУ СОІХЖ СВ+/В 

191 @ 4,К ЗАУ "^В СОІХЖ СВ+/В 

192 @ 5.К ЗАУ *^В СОІХЖ СВ+/В 

193 @ 6,К ЗАУ ‘|В а СОІХЖ СВ+/В 

194 ВЕТУВЫ 

195 

196 РВОСЕОУВЕ ОІЬетоІІ 

197 РАВАМЕТЕВ к 

198 @ 2,К ЗАУ 4В СОІХЖ ВС + 

199 @ 3,К ЗАУ "^В СОІХЖ ВС + 

200 @ 4,К ЗАУ "^В СОІХЖ ВС + 

201 @ 5, К ЗАУ V СОІХЖ ВС + 

202 @ 6,К ЗАУ С °УОВ ВС + 

203 ВЕТУВЫ 


12 - 6340 
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5.3. ПРИКЛАДНАЯ ПРОГРАММА РЕАЛИЗАЦИИ СЕРВИСНЫХ 
ФУНКЦИЙ ВЕДЕНИЯ БАЗ ДАННЫХ 

Прикладная программа Бегѵісе позволяет выполнять ряд сервисных функций, 
подобных управляющему центру сІВАБЕ IV. Кроме этого, исходя из опыта 
работы с пакетом сІВАБЕ IV, в данной программе реализованы некоторые 
полезные функции, которые нельзя выполнить непосредственно с помощью 
меню УЦ. 

Программа Бегѵісе дает возможность: 
создавать и изменять структуры БД; 
открывать, закрывать и переиндексировать файлы БД; 
редактировать введенные данные и добавлять записи; 
просматривать файлы БД и удалять записи; 
осуществлять поиск, отбор и сортировку данных; 
выполнять вывод данных на экран, принтер или в файл; 
устанавливать параметры и состояния сІВАБЕ IV; 
осуществлять экспорт-импорт файлов; 
вычислять размер свободной оперативной памяти; 
выполнять некоторые команды РОБ; 

осуществлять выход из программы в сІВАБЕ IV или РОБ. 

После входа в программу высвечивается основное горизонтальное меню с 
позициями "Файл БД", "Данные", "Поиск", "Вывод", "Сервис", "Выход", к 
которым прикрепляются многоуровневые вертикальные меню. 

Ниже на рис. 5.1 показана общая блок-схема программы Бегѵісе, а на рис. 
5.2...5.4 приведены блок-схемы ее ветвей, реализующие функции позиций 
вертикальных меню, прикрепленных к позициям основного горизонтального 
меню. 

Функции меню реализуются посредством соответствующей процедуры, имя 
которой помещено в блок-схеме над меню. Процедуры меню обеспечивают 
переход на следующий уровень или вызов исполняемой процедуры. 

При переходе на меню ниже следующего уровня вызывается процедура, 
связанная с этим меню. 

При переходе между позициями горизонтального меню автоматически 
высвечиваются прикрепленные к ним вертикальные меню. Активизация позиций 
вертикальных меню нижних уровней выполняется нажатием клавиши Епіег. 

Программа Бегѵісе состоит из главной процедуры и вызываемых процедур, 
выполняющих операции, связанные с выбранной позицией меню. В начале 
главной процедуры выполняются команды по установке параметров и состояний 
сІВАБЕ IV. 

Этими командами назначается частота и длительность звукового сигнала, 
подаваемого при заполнении последнего символа в поле записи файла БД; 
определяется тип рамки вокруг вертикальных меню; отменяется режим 
копирования содержимого предыдущей записи при переходе к новой записи 
файла БД; закрывается текущий каталог; восстанавливается расцветка экрана, 
задаваемая в сІВАБЕ IV по умолчанию; отменяется вывод часов на экране; 
выключается функция аварийного прерывания выполнения команд клавишей ЕБС 
и отменяется вывод на печать или экран выполняемых команд и их результатов; 
подавляется отображение на экране информационной строки текущего состояния 
системы сІВАБЕ IV. 

После установок системных параметров командой РІІВЫС определяются 
глобальные переменные, которые будут использоваться повсюду в программе. 
Некоторым из них присваиваются начальные значения. Например, символьной 
переменной те$$ присваивается справочный текст по использованию меню, 
который после выбора соответствующей позиции меню высвечивается в строке 
сообщений экрана. 
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Главная процедура 
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5.1. Общая блок-схема программы $егѵісе 
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схемы ветвей программы Зегѵісе 'Файл БД* и 'Данные 
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Рис. 5.3. Блок-схемы ветвей программы Зегѵісе 'Поиск" и 'Вывод 
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Рис. 5.4. Блок-схемы ветвей программы Зегѵісе “Сервис" и ‘Выход 













I 


• Зегуіее.ргв 

1 8ЕТ ВЕІХ ТО 60,10 

2 8ЕТ БОКОВЕ ТО 8ІЫСЬЕ 

3 8ЕТ СЛККѴ ОРР 

4 8ЕТ САТАЬОС ТО 

5 8ЕТ СОЬОК ТО 

6 8ЕТ СЬОСК ОРР 

7 8ЕТ Е8САРЕ ОРР 
88ЕТ ЕСНО ОРР 

9 8ЕТ РКІЫТ ОРР 

10 8ЕТ ТАІЛС ОРР 

И ЗЕТ 8СОКЕВОАКО ОРР 

12 8ЕТ 8ТАТ118 ОРР 

13 РІІВІЛС 1п_ІуреДп_гкеу,1іі_гес,1іі_пит,1<1_<1аіе,1с_орііоіі,; 

14 I г,8П_еггог,$п_ікеу ,вп_*еш1 ,*с_кеу ,1 іі(ѵ а 1 ,тем 

15 Іг=арасе(8) 

16 ^п сггог =0 

17 яп_ікеу =0 

18 {п_ив(1 =0 

19 *с_кеу-’Н’ 

20 ІіаТѵаІ-’Ж^РІЕІЛ)’ 

21 тем=’Персход между позициями: ЧСНК(27)+СНК(26)+* 

22 +СНК(25) +СНК(24)+’ Выбор позиции: *; 

23 +СНК( 17) +СНК( 196) +СНК(217)+’ Помощь: РГ 

24 


Команда ОЕРІЫЕ ѴѴІЫРОѴѴ определяет окно с именем Раи$е, которое в 
дальнейшем будет использоваться для вывода сообщений об ошибках или 
различных комментариев. Обработка ошибочной ситуации выполняется командой 
ОЫ ЕККОК. Эта команда в случае такой ситуации вызывает процедуру Раиье, 
передавая ей через параметры имя процедуры и номер строки, в которой 
произошла ошибка. Команда ОЫ КЕѴ І.АВЕІ назначает клавише Р1 вызов с 
помощью процедуры НІрзсг на экран справочной информации. Затем последова¬ 
тельно запускаются процедуры: ТііиІ (вывод заставки программы Зегѵісе); Мр4е{ 
(определение окон, горизонтального и вертикальных меню) и Соіог (расцветка 
экрана). 

25 ОЕРІЫЕ ШІЫІЮШ Раисе РВОМ 15,5 ТО 19,75 ИОЫЕ СОЬОК Ѵ/+/К 

26 ОЫ ЕККОК IX) Раисе >ѴГГН 'Процедура: ЧРговгат()+; 

27 ’ Строка : ’+ЬТКІМ(8ТК(ЫМЕ())) 

28 ОЫ КЕѴ ЬАВЕЬ Р1 IX) Шрасг 

29 IX) Тііиі 

30 ІЮ МрйеІ 

31 


В составе главной процедуры основной командой является команда цикла 
ЭО ѴѴНИ-Е...ЕЫООО, в теле которой находится команда АСТІѴАТЕ МЕЫІІ ОІ, 
активизирующая основное горизонтального меню ОІ с прикрепленными к его 
позициям вертикальными меню. Условием входа в цикл служит значение 
переменной дс_ кеу = 'Н\ После выбора позиции "йЬазе IV" вертикального меню 
Р6, прикрепленного к позиции "Выход", в процедуре Рор_Р6, которая 
вызывается при активизации меню Р6, командой ОЕАСТІѴАТЕ МЕЫІІ деактивизи- 
руется меню ОІ и активизируется окно Ехіі_Арр (в нем высвечивается 
предложение ввести букву "Д" для выхода из программы). При вводе вуквы 
"Д" осуществляется выход из цикла ЭО Ѵ/НИЕ...ЕЫООО и управление передается 
на завершающую часть главной процедуры. В противном случае снова 
активизируется горизонтальное меню ОІ. При выборе позиции "бОЗ" меню 
"Выход" переход в 005 осуществляется без высвечивания сообщения. 

В завершающей части главной процедуры закрываются все файлы и 
процедуры, оперативная память очищается от переменных, меню и окон, 
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клавишам Р1 и Е$с возвращаются их первоначальные функции и команда ГСЕТІЖЫ 
осуществляет выход из программы. 

32 IX) ЛѴНІЬЕ «с кеу =’Н’ 

33 еюсоіхж” 

34 ЗЕТ 5ТАТЫ5 (Ж 

35 АСТІѴАТЕ МЕЬШ ОІ 

36 ЭЕРЖЕ \ѴІЫОО\Ѵ ЕхііАрр РКОМ 9,17 ТО 12,62 ЖЖЕ СОЬОК АѴ+/К 

37 ЗЕТ МЕЗЗАСЕ ТО; 

38 'Для выбора нужного ответа (Да/Нет) нажмите ЗрасеЬаг ’ 

39 АСТІѴАТЕ ШЖСЮѴ/ Ехіі Арр 

40 @ 1,1 ЗАѴ "Вы хотите завершить работу с системой ? 

41 СЕТ «с кеу РІСТ "@М Д,Н" 

42 КЕАО ~ 

43 СЬЕАК СЕТ5 

44 ЗЕТ МЕЗЗАСЕ ТО 

45 ОЕАСТІѴАТЕ ШІИООѴѴ Ехіі Арр 

46 ЕЫОЕЮ 

47 

48 СЖ КЕѴ ЬАВЕЬ Р1 

49 СЬЕАК АІХ 

50 СЬЕАК \ѴІЫІХ)\Ѵ8 

51 СЬЕАЕ РОРІІРЗ 

52 СЬОЗЕ АІХ 

53 СХОЗБ РЕОСЕОІІЕЕ 

54 ЗЕТ Е8САРЕ (Ж 

55 ЗЕТ МЕЗЗАСЕ ТО 

56 СЬЕАК 

57 КЕТ11КН && Выход из программы Зегѵісе 

58 


Вторая часть программы Зегѵісе содержит вызываемые процедуры, 
которые разделяются на четыре группы. К первой группе относятся процедуры, 
которые вызываются непосредственно из главной процедуры и упомянуты выше. 
Вторая группа включает процедуры, вызываемые при активизации вертикальных 
меню различных уровней. Эти процедуры имеют такие же имена, как и меню, 
но с приставкой впереди Рор _. 

В состав третьей группы входят процедуры, вызываемые при выполнении 
определенных позиций меню: ЗеагсЬ, Зогі, Ргі_тепи, РгіпіоиІ. Четвертая группа 
состоит из процедур, имеющих общее назначение, которые вызываются для 
реализации определенных функций: Іп(о_Ьох, Раи$е, НІр$сг и ВеІІ. Схема вызова 
процедур приведена на рис. 5.1...5.4. 

Вызываемые процедуры могут располагаться во второй части программы 
в любой последовательности. Однако для лучшего понимания работы программы 
Зегѵісе целесообразно в начале поместить процедуру МрсЫ. 

Процедура Мр4е{ определяет сначала окна, затем горизонтальное и 
вертикальные меню, используемые в программе. Окно Заѵезсг предназначено 
для вывода различной информации на полном (по ширине) экране. В окне 
Неірзсг выводится справочная информации по использованию меню. Окно Вгоѵѵзсг 
используется для вывода записей файла БД в форме Вгоѵѵзе, а окно Раизе - для 
вывода сообщения об ошибке. В окне Мргіпі выводятся параметры, устанавливае¬ 
мые перед печатью отчета или марки. В окне Тіііе задается имя текстового 
файла при выводе в него отчета или марки. 

В процедуре МрсІеІ после определения порции окон и меню командой 
@...ЗАѴ в строке сообщений экрана высвечивается слово "Загрузка..." и 
движущиеся символы , отражающие течение процесса определения меню и 
окон. По завершению этого процесса появляется надпись "100 %". 
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59 РЕОСЕОІІЕЕАІр<іеГ 

60 ОЕРШЕ ^ШОО>Ѵ РиІІЗсг РЕОМ 0,0 ТО 24,79 ИОЫЕ 

61 ОЕРШЕ \ѴШІХ>\Ѵ Заѵс$сг РЕОМ 0,0 ТО 21,79 ЫОЫЕ 

62 ОЕРШЕ \ѴШООЧѴ Неірвсг РЕОМ 3,0 ТО 19,79 ЫОЫЕ СОЬОЕ ВС+/В 

63 ОЕРШЕ \ѴШІЮ\Ѵ Вгоѵвсг РЕОМ 1,0 ТО 21,79 ЫОЫЕ 

64 ОЕРШЕ >ѴШОО\Ѵ Мргіпі РЕОМ 4,5 ТО 20,67 ЖШЕ СОЬОЕ ВС+/В 

65 ОЕРШЕ \ѴШООЧѴ ТПІс РЕОМ 123 ТО 1537 ЫОЫЕ СОЬОЕ ОЕ+/С + 

66 @ 23,20 ЗАѴ "Загрузка...' 

67 ЗЕТ СОЬОЕ ТО Е + 

68 

Затем определяется горизонтальное меню ОІ, его позиции и назначается 
активизация вертикальных меню при выборе этих позиций. Например, при 
выборе позиций "Файл БД" основного (горизонтального) меню активизируется 
вертикальное меню Р1. 

69 ОЕРШЕ МЕЬШ С1 

70 ОЕРШЕ РАО Ра<1_1 ОР ОІ РЕОМРТ'Файл БД' АТ 13 

71 ОЕРШЕ РАО Ра<1~2 ОР ОІ РЕОМРТ 'Данные ' АТ 1,18 

72 ОЕРШЕ РАО Ра<1_3 ОР ОІ РЕОМРТ “ Поиск ' АТ 130 

73 ОЕРШЕ РАО Ра<!_4 ОР С1 РЕОМРТ ' Вывод ' ЛТ 1,43 

74 ОЕРШЕ РАО Ра<1_5 ОР ОІ РЕОМРТ 'Сервис ' АТ 137 

75 ОЕРШЕ РАО Ра<! 6 ОР ОІ РЕОМРТ ' Выход ' АТ 1,68 

76 ОЫ РАО Ра<!_1 ОР ОІ АСТІѴЛТЕ РОРЦР Р1 

77 ОЫ РАО Рас! 2 ОР С1 АСТ1ѴАТЕ РОР IIР Р2 

78 ОЫ РАО Рас! 3 ОР С1 АСТ1ѴАТЕ РОРТІР РЗ 

79 ОЫ РАО Рас! 4 ОР ОІ АСТІѴАТЕ РОРИР Р4 

80 ОЫ РАО Рас!_5 ОР С1 АСТІѴАТЕ РОРЦР Р5 

81 ОЫ РАО Рас! 6 ОР ОІ АСТІѴАТЕ РОРЦР Р6 

82 

В вертикальном меню Р1 определяется восемь позиций, из которых 
активными являются только шесть. Третья и седьмая позиции неактивны (при 
движении курсора эти позиции пропускаются), на что указывает опция 5КІР в 
команде РЕРІЫЕ ВАК. При активизации меню в информационной строке экрана 
высвечивается сообщение, записанное в переменной те$5. Реализация функций 
меню Р1 выполняется в процедуре Рор_Р1. 

83 ОЕРШЕ РОРТІР Р1 РЕОМ 3,2 ТО 12,23 МЕ55АСЕ тек 

84 ОЕРШЕ ВАЕ 1 ОР Р1 РЕОМРТ ' Открыть 

85 ОЕРШЕ ВАЕ 2 ОР Р1 РЕОМРТ ' Закрыть 

86 ОЕРШЕ ВАЕ 3 ОР Р1 РЕОМРТ '- 

87 ОЕРШЕ ВАЕ 4 ОР Р1 РЕОМРТ ' Создать 

88 ОЕРШЕ ВАЕ 5 ОР Р1 РЕОМРТ ' Изменить 

89 ОЕРШЕ ВАЕ 6 ОР Р1 РЕОМРТ ' Переиндексировать " 

90 ОЕРШЕ ВАЕ 7 ОР Р1 РЕОМРТ '- 

91 ОЕРШЕ ВАЕ 8 ОР Р1 РЕОМРТ ' Скопировать 

92 ОЫ ЗЕЬЕСТКШ РОРІІР Р1 ОО РорРІ 

93 

Затем определяется вертикальное меню Р11, в котором высвечивается 
список файлов заданного типа, определяемого опцией ЫКЕ команды РЕРІЫЕ 

РОРІІР. При активизации меню Р11 осуществляется вызов процедуры Рор_Р1 1. 

Далее определяются вертикальные меню Р2, Р21, Р22, Р23, РЗ и др. 

94 ОЕРШЕ РОРЦР Р11 РЕОМ 5,18 ТО 20,33 РЕОМРТ РІБЕ5 ЫКЕ ѴсіЬГ 

95 ОІЯ ЗЕЬЕСТЮН РОРЦР Р11 ОО Рор РИ 

96 ?? СНЕ(176) 

97 

98 ОЕРШЕ РОРЫР Р2 РЕОМ 3,18 ТО 11,38 МЕ55АСЕ тек 

99 ОЕРШЕ ВАЕ 1 ОР Р2 РЕОМРТ ' Редактировать " 


' 5КІР 


5КІР 
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8КІР 


100 ОЕРШЕ ВАК 2 ОР Р2 РКОМРТ -- 

101 ОЕРШЕ ВАК 3 ОР Р2 РКОМРТ а Добавить 

102 ОЕРШЕ ВАК 4 ОР Р2 РКОМРТ а -" 8КІР 

103 ОЕРШЕ ВАК 5 ОР Р2 РКОМРТ * Удалить 

104 ОЕРШЕ ВАК 6 ОР Р2 РКОМРТ а -* 8КІР 

105 ОЕРШЕ ВАК 7 ОР Р2 РКОМРТ • Просмотреть - 

106 ОИ 8ВЬЕСТЮЫ РОРІІР Р2 IX) Рор_Р2 

107 77 СНК(176) 

108 

109 ОЕРШЕ РОРІІР Р21 РКОМ 631 МЕ88АСЕ тем 
ПО ОЕРШЕ ВАК 1 ОР Р21 РКОМРТ * Одну запись (Е<Ж) 

111 ОЕРШЕ ВАК 2 ОР Р21 РКОМРТ *-’ 8К1Р 

112 ОЕРШЕ ВАК 3 ОР Р21 РКОМРТ а Список записей (Вгошае) а 

113 ОЫ 8ЕЬЕСТЮЫ РОРІІР Р21 IX) Рор_Р21 

114 77 СНК(176) 

115 

116 ОЕРШЕ РОРІІР Р22 РКОМ 631 ТО 10,63 МЕ88АСЕ тем 

117 ОЕРШЕ ВАК 1 ОР Р22 РКОМРТ а Запись в конец БД 

118 ОЕРШЕ ВАК 2 ОР Р22 РКОМРТ а - а 8КІР 

119 ОЕРШЕ ВАК 3 ОР Р22 РКОМРТ а Пустую запись после текущей* 

120 ОЫ 5ЕЬЕСГЮМ РОРІІР Р22 IX) Рор_Р22 

121 ?? СНК(Г76) 

122 

123 ОЕРШЕ РОРІІР Р23 РКОМ 731 ТО 13,71 МЕ88АСЕ тем 

124 ОЕРШЕ ВАК 1 ОР Р23 РКОМРТ "Пометить все удаляемые записи” 

125 ОЕРШЕ ВАК 2 ОР Р23 РКОМРТ 4 -- 8КІР 

126 ОЕР1ІЧЕ ВАК 3 ОР Р23 РКОМРТ а Снять все метки для удаления” 

127 ОЕРШЕ ВАК 4 ОР Р23 РКОМРТ ”-” 5КІР 

128 ОЕРШЕ ВАК 5 ОР Р23 РКОМРТ " Удалить помеченные записи а 

129 ОЫ ЗЕЬЕСПОЫ РОРІІР Р23 IX) Рор Р23 

130 77 СНК(176) 

131 

132 ОЕРШЕ РОРІЛ» РЗ РКОМ 330 ТО 11/47 МЕ88АСЕ тем 

133 ОЕРШЕ ВАК 1 ОР РЗ РКОМРТ а Поиск 

134 ОЕРШЕ ВАК 2 ОР РЗ РКОМРТ "-' 8КІР 

135 ОЕРШЕ ВАК 3 ОР РЗ РКОМРТ а Запрос 

136 ОЕРШЕ ВАК 4 ОР РЗ РКОМРТ ”- а 8КІР 

137 ОЕРШЕ ВАК 5 ОР РЗ РКОМРТ а Сортировка а 

138 ОЕРШЕ ВАК 6 ОР РЗ РКОМРТ ”-" 8КІР 

139 ОЕРШЕ ВАК 7 ОР РЗ РКОМРТ а Запись N а 

140 ОЫ ЗЕиВСГКШ РОРІІР РЗ IX) Рор РЗ 

141 77 СНК(176) 

142 

143 ОЕРІИЕ РОРПР Р32 РКОМ 6/43 МЕ88АСЕ тем 

144 ОЕРШЕ ВАК 1 ОР Р32 РКОМРТ ' Активизировать а 

145 ОЕРШЕ ВАК 2 ОР Р32 РКОМРТ ”-- 8КІР 

146 ОЕРІЫЕ ВАК 3 ОР Р32 РКОМРТ а Изменить 

147 ОЕРШЕ ВАК 4 ОР Р32 РКОМРТ - -” 8КІР 

148 ОЕРШЕ ВАК 5 ОР Р32 РКОМРТ а Создать 

149 ОЫ ЗЕЬЕСГКШ РОРИР Р32 IX) Рор_Р32 

150 7? СНК(176) 

151 

152 ОЕР1ЫЕ РОРЦР Р34 РКОМ 8/44 ТО 14,71 МЕ88АСЕ тем 

153 ОЕРШЕ ВАК 1 ОР Р34 РКОМРТ а Первая запись 

154 ОЕРШЕ ВАК 2 ОР Р34 РКОМРТ ”-” 8КІР 

155 ОЕРШЕ ВАК 3 ОР Р34 РКОМРТ а Последняя запись 

156 ОЕРШЕ ВАК 4 ОР Р34 РКОМРТ *-” 8КІР 

157 ОЕРШЕ ВАК 5 ОР Р34 РКОМРТ а Перейти к записи N 1 

158 МЕ88АСЕ 'Введите номер записи’ 

159 ОЫ ЗЕЬЕСПОЫ РОРІІР Р34 IX) Рор_Р34 

160 7? СНК(176) 

161 
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162 ОЕРІЫЕ РОРЦР Р321 РКОМ 9,55 ТО 19,70 РКОМРТ Р1ЬЕ5 ІЛКЕ ѴОВЕ 

163 ОЫ ЗЕЕЕСПОЫ РОРІЛ» Р321IX) Рор_Р321 Ѵ/ГГН АА 

164 П СНК(176) 

165 

166 ОЕРІЫЕ РОРЫР Р4 РКОМ 3/43 ТО 9,63 МЕЗЗАСЕ те» 

167 ЭЕРІЫЕ ВАК 1 ОР Р4 РКОМРТ ' Экранная форма а 

168 ОЕРІЫЕ ВАК 2 ОР Р4 РКОМРТ 4 - а ЗКІР 

169 ОЕРІЫЕ ВАК 3 ОР Р4 РКОМРТ а Отчет 

170 ОЕРІЫЕ ВАК 4 ОР Р4 РКОМРТ *-- ЗКІР 

171 ОЕРІЫЕ ВАК 5 ОР Р4 РКОМРТ ■ Марка 

172 ОЫ ЗЕЬЕСПОЫ РОРЦР Р4 IX) РорР4 

173 ?? СНК(176) 

174 

175 ОЕРІЫЕ РОР11Р Р41 РКОМ 5,55 ТО 11,71 МЕЗЗАСЕ те» 

176 ОЕРІЫЕ ВАК 1 ОР Р41 РКОМРТ " Подключить ■ 

177 ОЕРІЫЕ ВАК 2 ОР Р41 РКОМРТ --• ЗКІР 

178 ОЕРІЫЕ ВАК 3 ОР Р41 РКОМРТ ' Создать 

179 ОЕРІЫЕ ВАК 4 ОР Р41 РКОМРТ 4 - а ЗКІР 

180 ОЕРІЫЕ ВАК 5 ОР Р41 РКОМРТ " Изменить а 

181 ОЫ ЗЕЕЕСПОЫ РОР11Р Р41 ІЮ Рор Р41 ДѴІТН ВВ 

182 ?? СНК(176) 

183 

184 ОЕРІЫЕ РОРЫР Р42 РКОМ 11,43 МЕЗЗАСЕ те» 

185 ОЕРІЫЕ ВАК 1 ОР Р42 РКОМРТ " Вывести: а ЗКІР 

186 ОЕРІЫЕ ВАК 2 ОР Р42 РКОМРТ а -- ЗКІР 

187 ОЕРІЫЕ ВАК 3 ОР Р42 РКОМРТ " - на печать 

188 ОЕРІЫЕ ВАК 4 ОР Р42 РКОМРТ '- а ЗКІР 

189 ОЕРІЫЕ ВАК 5 ОР Р42 РКОМРТ а - в текстовый файл а 

190 ОЕРІЫЕ ВАК 6 ОР Р42 РКОМРТ *- а ЗКІР 

191 ОЕРІЫЕ ВАК 7 ОР Р42 РКОМРТ а - на экран 

192 ОЫ ЗЕЬЕСПОЫ РОРІІР Р42 ІЮ Рор_Р42 

193 ?? СНК(176) 

194 

195 ОЕРІЫЕ РОРІ1Р Р411 РКОМ 9,63 ТО 20,77 РКОМРТ РІЬЕЗ ІЛКЕ а Лші 

196 ОЫ ЗЕЬЕСПОЫ РОРЧР Р411 ІЮ Рор Р411 

197 ?? СНК(176) 

198 

199 ОЕРІЫЕ РОР11Р Р413 РКОМ 9,63 ТО 20,77 РКОМРТ РІЬЕЗ ІЛКЕ а лсг 

200 ОЫ ЗЕЬЕСПОЫ РОРЬІР Р413 ІЮ Рор Р413 

201 ?? СНК(176) 

202 

203 ОЕРІЫЕ РОР11Р Р421 РКОМ 9,63 ТО 20,77 РКОМРТ РІЬЕЗ ІЛКЕ а Лг 8 

204 ОЫ ЗЕЬЕСПОЫ РОРЫР Р421 ІЮ Рор Р421 

205 П СНК(176) 

206 

207 ОЕРІЫЕ РОРІ1Р Р423 РКОМ 9,63 ТО 20,77 РКОМРТ РІЬЕЗ ЫКЕ Мгш 

208 ОЫ ЗЕЬЕСПОЫ РОР11Р Р423 ІЮ Рор_Р423 

209 ?? СНК(176) 

210 

211 ОЕРІЫЕ РОРЦР Р431 РКОМ 9,63 ТО 20,77 РКОМРТ РІЬЕЗ ЫКЕ МЬ^ 

212 ОЫ ЗЕЬЕСПОЫ РОР11Р Р431 ІЮ Рор_Р431 

213 ?? СНК(176) 

214 

215 ОЕРІЫЕ РОРІ1Р Р433 РКОМ 9,63 ТО 20,77 РКОМРТ РІЬЕЗ ІЛКЕ • ЛЫ 

216 ОЫ ЗЕЬЕСПОЫ РОРЫР Р433 ІЮ Рор_Р433 

217 ?? СНК(176) 

218 

219 ОЕРІЫЕ РОРЫР Р5 РКОМ 3,48 МЕ55АСЕ те» 

220 ОЕРІЫЕ ВАК 1 ОР Р5 РКОМРТ а Установки сІВАЗЕ IV а 

221 ОЕРІЫЕ ВАК 2 ОР Р5 РКОМРТ а - 

222 ОЕРІЫЕ ВАК 3 ОР Р5 РКОМРТ а Экспорт 

223 ОЕРІЫЕ ВАК 4 ОР Р5 РКОМРТ а Импорт 


ЗКІР 



5КІР 


224 БЕРІЫЕ ВАК 5 ОР Р5 РКОМРТ 4 - 

225 БЕРІЫЕ ВАК б ОР Р5 РКОМРТ - Копировать 

226 БЕРІЫЕ ВАК 7 ОР Р5 РКОМРТ 4 -' 5КІР 

227 БЕРІЫЕ ВАК 8 ОР Р5 РКОМРТ * Удалить 

228 БЕРІЫЕ ВАК 9 0РР5 РКОМРТ '-' 5К1Р 

229 БЕРІЫЕ ВАК 10 ОР Р5 РКОМРТ а Переименовать 

230 БЕРІЫЕ ВАК 11 ОР Р5 РКОМРТ '-- 5К1Р 

231 БЕРІЫЕ ВАК 12 ОР Р5 РКОМРТ " Редактор текста * 

232 БЕРІЫЕ ВАК 13 ОР Р5 РКОМРТ 4 --' 8КІР 

233 БЕРІЫЕ ВАК 14 ОР Р5 РКОМРТ ■ Память 

234 ОЫ 8ЕБЕСПОЫ РОРБР Р5 IX) Рор Р5 

235 ?? СНК(Г76) 

236 


237 БЕРІЫЕ РОРБР Р52 РКОМ 7,60 ТО 15,77 МЕ88АСЕ шея 

238 БЕРІЫЕ ВАК 1 ОР Р52 РКОМРТ "^РР5 

239 БЕРІЫЕ ВАК 2 ОР Р52 РКОМРТ *-- 8КІР 

240 БЕРІЫЕ ВАК 3 ОР Р52 РКОМРТ * <ША8Е II 

241 БЕРМЕ ВАК 4 ОР Р52 РКОМРТ *-- 8КІР 

242 БЕРМЕ ВАК 5 ОР Р52 РКОМРТ * Ргатсѵогк 11 " 

243 БЕРМЕ ВАК 6 ОР Р52 РКОМРТ '-■ 8КІР 

244 БЕРМЕ ВАК 7 ОР Р52 РКОМРТ ■ КаркІРіІе " 

245 ОЫ 8ЕБЕСПОЫ РОРБР Р52 БО Рор Р52 

246 ?? ' 100 % и 
2А1 

248 БЕРІЫЕ РОРБР Р53 РКОМ 7,60 ТО 17,77 МЕ58ЛСЕ те» 

249 БЕРІЫЕ ВАК 1 ОР Р53 РКОМРТ " РР8" 

250 БЕРІЫЕ ВАК 2 ОР Р53 РКОМРТ 4 -■ 8КІР 

251 БЕРІЫЕ ВАК 3 ОР Р53 РКОМРТ ■ «ІВА5Е II' 

252 БЕРІЫЕ ВАК 4 ОР Р53 РКОМРТ '-' 8КІР 

253 БЕРІЫЕ ВАК 5 ОР Р53 РКОМРТ ■ КаркІРіІе' 

254 БЕРІЫЕ ВАК 6 ОР Р53 РКОМРТ а -" 8КІР 

255 БЕРІЫЕ ВАК 7 ОР Р53 РКОМРТ ' Ргатеѵогк II' 

256 БЕРІЫЕ ВАК 8 ОР Р53 РКОМРТ '-" 8КІР 

257 БЕРІЫЕ ВАК 9 ОР Р53 РКОМРТ ' ШКГ 

258 ОЫ 8ЕБЕСПОЫ РОРБР Р53 БО Рор Р53 

259 

260 БЕРІЫЕ РОРБР Р6 РКОМ 3,60 ТО 7,79 МЕ88АСЕ тая 

261 БЕРІЫЕ ВАК 1 ОР Р6 РКОМРТ ' Сопігоі Сепіег " 

262 БЕРІЫЕ ВАК 2 ОР Р6 РКОМРТ '-" 8КІР 

263 БЕРІЫЕ ВАК 3 ОР Р6 РКОМРТ ' В08 

264 ОЫ 5ЕБЕСПОЫ РОРБР Р6 БО Рор Рб 

265 КЕТБКЫ 

266 


За процедурой Мрсіе{ помещаются процедуры, реализующие функции 
прикладной программы Зегѵісе, которые вызываются при активизации вертикаль¬ 
ных меню. Процедура Рор_Р1 вызывается при активизации вертикального меню 
Р1 и реализует функции открытия, закрытия, создания и переиндексации файла 
БД, изменения и копирования его структуры. Основой процедуры служит 
команда ЭО САЗЕ... ЕЫОСАЗЕ, позволяющая разветвлять управление в 
зависимости от выбранной позиции меню. Например, после выбора позиции 
"Открыть" управление передается на команду АСТІѴАТЕ РОРІІР Р11 после опции 
САЗЕ ВАК() = 1, в результате чего активизируется вертикальное меню РП, 

которое определено в процедуре Мрсіеі. С помощью этого меню пользователь 
выбирает файл, который нужно открыть. 

267 РКОСЕББКЕ Рор РІ 

268 БО СА8Е 

269 СА8Е ВАК() = 1 АА Открыть 

270 АСТІѴАТЕ РОРБР Р11 

271 СА8Е ВАК() = 2 АА Закрыть 
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272 АСТІѴАТЕ ШШГЮШ Заѵеасг 

273 ШЕ 

274 ОЕАСТІѴАТЕ ѴѴІЫООШ Заѵеасг 

275 САЗЕ ВАК() = 4 ДА Создать 

276 АСТІѴАТЕ ШІЫІЮШ Заѵеасг 

277 М=ЗРАСЕ(8) 

278 @ 5,15 іо 7,60 

279 @ 6,18 ЗЛУ "Введите имя новой базы данных " СЕТ Ьй 

280 КЕАО 

281 СЕНАТЕ АЬё 

282 СЬЕАК СЕТЗ 

283 ОЕАСТГѴАТЕ Заѵеасг 

284 САЗЕ ВАК() = 5 ДА Изменить 

285 АСГІѴАТЕ ѴІЫООѴ Заѵеасг 

286 МСЮІРУ 8ТІШСТІЛШ 

287 ОЕАСТІѴАТЕ >ѴІЫІЮ\Ѵ Заѵеасг 

288 САЗЕ ВАК() = 6 АА Перенндекснровать 

289 АСТІѴАТЕ \ѴІЫЕЮ\Ѵ Заѵеасг 

290 1с_аау=’ Переиндексация базы данных...* 

291 об іпіоЬох 1ѴГГН Ісаау 

292 ЗЕТ ТАІЛС ОЫ 

293 КЕШОЕХ 

294 ЗЕТ ТАЬК ОРР 

295 ОЕАСТІѴАТЕ ЛѴІЫООШ Заѵеасг 

296 САЗЕ ВАК() = 8 АД Копировать 

297 АСТІѴАТЕ \ѴШОО\Ѵ Заѵеасг 

298 М=8РАСЕ(8) 

299 @ 5,15 (о 7,60 

300 @ 6,17 ЗАУ "Введите имя базы данных а СЕТ М 

301 КЕАО 

302 СЬЕАК СЕТЗ 

303 СОРУ 8ТІШСТГ1ЖЕ ТО АЬё 

304 ОЕАСТІѴАТЕ ЛѴІЫГЮШ Заѵеасг 

305 ЕЫОСАЗЕ 

306 ЗЕТ МЕЗЗАСЕ ТО 

307 ОЕАСТІѴАТЕ РОРІІР 

308 КЕТЫКИ 

309 


Процедура Рор_Р11 вызывается после выбора позиции "Открыть" 
вертикального меню Р1 при активизации меню Р11 и реализует функцию 
открытия существующего файла. Функция РКОМРТ() возвращает имя файла БД 
с маршрутом по директориям, выбранным из списка в окне вертикального меню 
Р11, которое присваивается переменной Іізіѵаі, и затем команда ІІЗЕ &Іі$іѵаІ 
открывает выбранный файл БД. Знак & функции макроподстановки означает, 
что в качестве имени открываемого файла используется не имя переменной, а 
ее содержимое. После открытия файла БД команда ОЕАСТІѴАТЕ РОРІІР 
деактивизирует вертикальное меню Р11, а команда РЕТЫРЫ выполняет возврат 
к процедуре Рор_Р1. 

310 РКОСЕОІЖЕ Рор РИ 

311 Ііаіѵаі =РКОМРТ() 

312 118Е Дііаіѵаі 

313 ЗЕТ МЕЗЗАСЕ ТО 

314 ОЕАСТІѴАТЕ РОРІІР 

315 КЕТІЖЫ 

316 


Процедура Рор_Р2 по своей структуре подобна процедуре Рор_Р1 и 
выполняет функции вертикального меню Р2 по редактированию, добавлению, 
удалению и просмотру записей открытого файла БД. 
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317 РКОСЕОИКЕ Рор_Й2 

318 ЕЮ САБЕ 

319 САБЕ ВАК() = 1 АА Редактировать 

320 АСТГѴАТЕ РОРИР Р21 

321 САБЕ ВАК() = 3 АА Добавить 

322 АСТІѴАТЕ РОРИР Р22 

323 САБЕ ВАК() = 5 АА Удалить 

324 АСТГѴАТЕ РОРИР Р23 

325 САБЕ ВАК() = 7 АА Просмотреть 

326 АСТГѴАТЕ ѴІЫІХИѴ Баѵевсг 

327 СИЕАК 

328 ОІБРЬАѴ АІХ 

329 БЕТ МЕББАСЕ ТО; 

330 а Для продолжения работы нажмите любую клавишу...” 

331 БЕТ СОЫБОИЕ ОРР 

332 ШАГГ 

333 БЕТ СОЫБОИЕ ОЫ 

334 ОЕАСТІѴАТЕ Ѵ/ІЫІЮ\Ѵ Баѵевсг 

335 ЕЫІЮАБЕ 

336 БЕТ МЕББАСЕ ТО 

337 ОЕАСТІѴАТЕ РОРИР 

338 КЕТІЖЫ 

339 


При выборе позиции "Редактировать" вертикального меню Р2 активизирует¬ 
ся вертикальное меню Р21 с двумя активными позициями. Реализация функций 
меню Р21 по редактированию записей файла БД в стандартных экранных формах 
ЕсМ или Вгоѵѵзе выполняется в процедуре Рор_Р21. 

340 РКОСЕОІЖЕ Рор Р21 

341 ГЮ САБЕ 

342 САБЕ ВАК() = 1 АА ЕсШ-форма 

343 ІР .поІ.РК=5РАСЕ(8) 

344 БЕТ РОКМАТ ТО АРК 

345 ЕЫОІР 

346 АСТІѴАТЕ ШІЫООѴ/ Вгоѵвсг 

347 ЕОГТ 

348 БЕТ РОКМАТ ТО 

349 ОЕАСТІѴАТЕ Ѵ/ІЫЕЮШ Вгошвсг 

350 САБЕ ВАК() = 3 АА Вгоѵве-таблнца 

351 АСТІѴАТЕ ШІЫІЮШ Вгоѵвсг 

352 ВКОШ5Е 

353 ОЕАСТІѴАТЕ Ѵ/ІЫСЮ\Ѵ Вгоѵвсг 

354 ЕЫОСАБЕ 

355 БЕТ МЕББАСЕ ТО 

356 ОЕАСТІѴАТЕ РОРИР 

357 КЕТИКЫ 

358 


Процедура Рор_Р22 вызывается при выборе позиции "Добавить" 
вертикального меню Р2 и реализует функции по добавлению записей в конец 
файла БД (командой АРРЕЫй) или же после текущей записи (командами ІЫ5ЕРТ 
ВЬАЫК и ЕЭІТ). 

359 РКОСЕОИКЕ Рор_Р22 

360 ГЮ САБЕ 

361 САБЕ ВАК() = 1 АА Добавить запись в конец БД 

362 АСТІѴАТЕ ШІЫЕЮѴ/ Вгошвсг 

363 АРРЕЫО 

364 ОЕАСТІѴАТЕ \ѴШООѴ Вгоѵвсг 

365 САБЕ ВАК() = 3 АА Добавить пустую запись после текущей 
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366 АСТІѴАТЕ ѴУ1ЫСЮШ 8аѵе*сг 

367 ІЫ8ЕКТ ВЬАЫК 

368 ЕОГГ 

369 ОЕАСТІѴАТЕ ШІЫІЮ\Ѵ 5аѵе*сг 

370 ЕЫОСА8Е 

371 8ЕТ МЕ88АСЕ ТО 

372 ОЕАСТІѴАТЕ РОРЬР 

373 КЕТОНЫ 

374 


Удаление записей файлов БД в 4ВА5Е IV выполняется в два этапа: пометка 
записей, предназначенных для удаления, и физическое удаление помеченных 
записей. Процедура Рор_Р23 выполняет пометку записей для последующего 
удаления, уничтожение этих пометок и физическое удаление помеченных записей 
файла БД. Вызывается при активизации вертикального меню Р23. 

375 РКОСЕОІЖЕ Рор_Р23 

376 ІЮ СА8Е 

377 СА8Е ВАК() = 1 АА Пометка записей для удаления 

378 АСТІѴАТЕ ШІЫЕЮШ 8аѵеасг 

379 1с_*ау =*Пометка записей для удаления...’ 

380 ІЮ ІпГоЬох \ѴІТН Іс аау 

381 8ЕТ ТАЬК ОЫ 

382 ОЕЬЕТЕ АЬЬ 

383 8ЕТ ТАЬК ОРР 

384 ОЕАСТІѴАТЕ \ѴІЫІЮ\Ѵ 8аѵеасг 

385 СА8Е ВАК() = 3 АА Снять все метки для удаления записей 

386 АСТІѴАТЕ ШІЫЕЮѴѴ 8аѵе*сг 

387 1с_аау =*Восстановление записей...’ 

388 ІЮ ІпГоЬох \ѴГГН Іс аау 

389 8ЕТ ТАЬК ОЫ 

390 КЕСАЬЬ АЬЬ 

391 8ЕТ ТАЬК ОРР 

392 ОЕАСТІѴАТЕ \ѴІЫОО>Ѵ 8аѵс*сг 

393 СА8Е ВАК() = 5 АА Удалить физически помеченные записи 

394 АСТІѴАТЕ >ѴІЫІЮ\Ѵ 8аѵе*сг 

395 1с_аау =’Физическое удаление записей...’ 

396 СЮ іпГо Ьох \ѴІТН Іс хау 

397 8ЕТ ТАЬК ОЫ 

398 РАСК 

399 8ЕТ ТАЬК ОРР 

400 СО ТОР 

401 ОЕАСТІѴАТЕ >ѴІЫГЮЛѴ 8аѵе*сг 

402 ЕЫІЮА8Е 

403 8ЕТ МЕ88АСЕ ТО 

404 ОЕАСТІѴАТЕ РОРЫР 

405 кетокы 

406 


Поиск информации в файле БД по заданному условию, отбор данных, 
сортировка записей, а также переход к записи по номеру выполняются с 
помощью вертикального меню РЗ, прикрепленного к позиции "Поиск" 
горизонтального меню <31. Функции меню РЗ реализует процедура Рор_РЗ. При 
выборе позиции "Поиск" вертикального меню осуществляется вызов процедуры 
поиска БеагсЬ. Выбор позиции "Запрос" активизирует вертикальное меню Р32, 
функции которого реализуются процедурой Рор _ Р32. 

Для сортировки записей после выбора позиции "Сортировка" выполняется 
процедура $огі. Выбор позиции "Запись Ы" меню активизирует вертикальное 
меню Р34, которое позволяет перейти к первой и последней записи, а также 
к записи с заданным номером. 
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407 РКОСЕОЕЖЕ Рор РЗ 

408 ЕЮ САЗЕ 

409 САЗЕ ВАК() = 1 АА Поиск 

410 ЕЮ ЗЕЛКСН 

411 СА8Е ВАК() = 3 АА Запрос 

412 АСТІѴАТЕ РОРЕ1Р Р32 

413 СА8Е ВАК() = 5 АА Сортировка 

414 ЕЮ ЗОКТ 

415 СА8Е ВАК() = 7 АА Запись N 

416 АСТІѴАТЕ РОРЕ1Р Р34 

417 ЕІЧЕ>САЗЕ 

418 8ЕТ МЕ88АСЕ ТО 

419 ОЕАСТІѴАТЕ РОРІЖ 

420 КЕТЕЖ1Ч 

421 


Процедура ЗеагсЬ выполняет два типа поиска: быстрый по индексному полю 
(выражению) и поиск записей по логическому выражению, составленному в 
соответствии с правилами отбора записей в языке сІВАЗЕ IV. 

Быстрый поиск осуществляется по активному в данный момент индексному 
полю (выражению) посредством ввода поискового значения, а поиск по условию 
выполняется с использованием сформированного пользователем выражения, 
содержащегося в переменных Іс_$ср (диапазон поиска), Іс_Іп2 (критерий 
поиска), Іп_ІпЗ (условие окончания поиска), и записанного в переменную 
Іс _ іетр. 


422 РКОСЕОІЖЕ 5ЕАКСІІ 

423 1Р ЬЕН(ОВРО) = 0 

424 ЕЮ Раите ЛѴГТН " НЕТ открытой базы данных* 

425 КЕТ ЕЖИ 

426 ЕИОІР 

427 ЗЕТ 8РАСЕ ОЫ 

428 8ЕТ ОЕЫМІТЕКЗ ОРР 

429 ІпГуре =0 АА Выбор подуровня 

430 Іпгкеу =КЕАОКЕѴ() АА Тест для Е5С или Ке(игп 

431 1п_гес =КЕСЫО() АА Номер записи 

432 1п пит =0 АА Для ввода числа 

433 Ісі сіаіе =ОАТЕ() АА Для ввода даты 

434 1с_ор(іоп =*0’ АА Главная опция (Зеек, Соіо апсі Ьосаіе) 

435 

436 5ТОКЕ ЗРАСЕ(Ю) ТО Істер 

437 5ТОКЕ 5РАСЕ(40) ТО Ісіпі, 1с_Іп2, ІсІпЗ 

438 1с_Іетр="“ 

439 АСТІѴАТЕ ШІЫЕЮѴѴ Заѵетег 


440 <2) 0,1 ЗАУ "Подключен индекс по полю : •+ІІР(""=ОКОЕК(),; 

441 "БД используется без индексного файла",ОКОЕК()); 

442 СОБОК ОК+/Ы 

443 1с_(етр =КЕРЫСАТЕ(СНК(196),19) 

444 <§Г2,0 8АѴ СНК(218)+1с_1етр+СНК(194)+1с_1етр+СНК(194)+; 

445 1с_1етр+СНК(194)+1с_1етр 

446 1п пит =240 


-Л' 


447 

448 ЕЮ ФНІБЕ Іппит < 560 

449 1с_Іетр=РІЕЫ)( (1п_пит-240)/20 +1) 

450 <§Г (1п_пит/80),МОО(1п_пит,80) 5АѴ СНК(179)+; 

451 Ісіетр +8РАСЕ(11-ЬЕЫОсІетр)) +; 

452 8ЕІВ8ТК("= Симв. = Дата = Догич.= Число = РІоаІ 

453 АТ(ТѴРЕ(1с_Іетр),"СОЕЫРМЕІ")*8-7,8) 

454 Іппит =!п_пит +20 

455 ЕЫОЕЮ 

456 


Мето 
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457 1п_пит =1 

458 ОЕРІЫЕ РОРУР Р31 РКОМ 8,25 

459 ОЕРІЫЕ ВАК 1 ОР Р31 РКОМРТ " Быстрый поиск по индексу ■; 

460 МЕ5БАСЕ * Поиск по индексному полю " 8КІР РОК ”=ОКОЕК() 

461 ОЕРІЫЕ ВАК 2 ОР Р31 РКОМРТ "-‘ 8К1Р 

462 ОЕРІЫЕ ВАК 3 ОР Р31 РКОМРТ а Поиск записей "; 

463 МЕББАСЕ "Поиск записей по заданному условию " 

464 ОЕРІЫЕ ВАК 4 ОР Р31 РКОМРТ "-" 5КІР 

465 ОЕРІЫЕ ВАК 5 ОР Р31 РКОМРТ " Выход в предыдущее меню 

466 МЕББАСЕ "Для выхода нажмите клавишу Епіег " 

467 С»Ы БЕЬЕСТЮЫ РОРУР Р31 ІЮ Рор РЗІ 

468 8ЕТ СОЫРІКМ ОЫ 

469 

470 ІЮ \ѴНІЬЕ Ісорііоп =’0’ 

471 АСТІѴАТЕ РОРУР Р31 

472 1с_орІіоп = І1гіт(с(г(&п_сепсі)) АА Для верт. меню 

473 

474 ІР ІА8ТКЕѴ() = 27 .ОК. Ісорііоп ="5" 

475 СОТО Іпгес 

476 ЕХІТ 

477 ЕЫОІР 

478 

479 ОО САБЕ 

480 САБЕ 1с_орІіоп=’Г АА Быстрый поиск 

481 ІР ЬЕЫ(ЫОХ(1))=0 АЫЭ. ЬЕЫ(МОХ(1))=0 

482 ІЮ Раи&е ДѴГТН "Нет открытых индексных файлов" 

483. ІХЮР 

484 ЕЫОІР 

485 

486 1п_1урс=“" 

487 1с_1п1 =5РАСЕ(45) 

488 ОЕРІЫЕ ^ІЫІЮ>Ѵ Роаіі2 РКОМ 8,13 ТО 15,62; 

489 ЫОЫЕ СОІХЖ +/В + 

490' АСТІѴАТЕ \ѴІЫЕЮ\Ѵ Ро*іі2 

491 @ 1,2 БАѴ "Нажатием клавиши БрасеВаг выберите тип поля" 

492 @ 2,5 БАѴ "(1 - символ, 2 - число и 3 = дата)"; 

493 СЕТ Іп іуре РІСТУКЕ "@М 1,2,3" СОЬОК \Ѵ/В + 

494 КЕАО 

495 

*496 ІР .ЫОТ. (КЕАОКЕѴО = 12 .ОК. КЕАОКЕѴ() = 268) 

497 БЕТ СОЫРІКМ ОЫ 

498 @ 4,14 БАѴ "Введите критерий поиска " СОЬОК ВС+"/В + 

499 

500 ІР 1п_іуре=’3’ 

501 @ 6,2 СЕТ Іб баіе РІСТ я @О я 

502 ЕЬБЕ 

503 

504 ІР 1п_Гуре=’2’ 

505 @ 6,2 СЕТ 1п пит РІСТ "##########" 

506 ЕЬБЕ 

507 @ 6,2 СЕТ Іс_1п1 

508 ЕЫОІР 

509 

510 ЕЫОІР 

511 КЕАО 

512 БЕТ СРЫРІКМ ОРР 

513 

514 ІР .ЫОТ. (КЕАОКЕѴ() = 12 .ОК. КЕАОКЕѴ() = 268) 

515 1с_іетр=ІІР(1п_іуре=’1\"ТКІМ(1с_1п1)",; 

516 І1Р(Іп_Іуре=’2\"1п пит","1<1 <1аіе")) 

517 БЕЕКЛІсіетр. 

518 ЕЫОІР 
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519 

520 ЕЫОІР 

521 КЕІ.ЕА8Е \ѴІЫІЮ\Ѵ$ Росіі2 

522 СА8Е 1с_ор(іоп =3* А& Поиск 

523 ОЕРІЫЕ ѴЛЫООѴѴ Роеіі2 РКОМ 8,8 ТО 14,77; 

524 ЫОЫЕ СОЬОК Ш +/ВК + 

525 АСГГѴАТЕ >ѴІЫООЧѴ Ро*іі2 

526 @ 1,22 8АУ • (АІХ, ЫЕХТ <п>, ап<1 КЕ5Т)' 

527 @ 1,01 8АУ -Диапазон:- ОЕТ Іссср 

528 @ 3,01 5АУ -Критерий поиска: СЕТ 1с_1п2 

529 @ 5,01 5АУ "Условие окончания поиска:" СЕТ 1с ІпЗ 

530 КЕЛЭ 

531 

532 ІР .ЫОТ. (КЕАРКЕУ() = 12 .ОК. КЕАОКЕУ() = 268) 

533 1с_(етр=ТКІМ(1с_сср) 

534 1с~(етр =1с_(етр + ІІР(ЬЕЫ(ТКІМ(1с_1п2)) > 0,*; 

535 РОК “ +ТКІМ(1с_1п2),—) 

536 1с_(етр =1с_1етр + ІІР(ЬЕЫ(ТКІМ(1с_1пЗ)) > 0,-; 

537 ШНІЬЕ ■ +ТКІМ(1с_1пЗ),—) 

538 

539 ІР ЬЕ1Ч(1с_<етр) > 0 

540 ЬОСАТЕ Аісіетр. 

541 ЕОІТ 

542 ЕЬ8Е 

543 ІЮ Ра и ее ШІТН "ВЫ не заполнили ни одной позиции..." 

544 ЕЫОІР 

545 

546 ЕЫОІР 

547 КЕЬЕАЗЕ Ѵ/ІЫООѴ/ Ро*й2 

548 ЕЫІЮА8Е 

549 ІР ЕОР() 

550 ІЮ Раисе >УГГН "Запись нс найдена ..." 

551 СОТО 1п гес 

552 ЕЫОІР 

553 

554 ІР КЕАОКЕУ() =12 .ОК. КЕАОКЕУ()= 268 .ОК. ЬА8ТКЕУ()=27 

555 1с_ор(іоп =’0’ 

556 ЕЫОІР 

557 

558 ЕЫОЕЮ 

559 ОЕАСТІѴАТЕ \ѴІЫОО>Ѵ Заѵессг 

560 8ЕТ СОЫРІКМ ОРР 

561 СЬЕАК СЕТ8 

562 КЕТІЖЫ 

563 


Процедура Рор_Р31 определяет номер выбранной позиции вертикального 
меню с именем Р31 и присваивает этот номер переменной дп_$епсі. 

564 РКОСЕОІЖЕ Рор рЗІ 

565 вп еепб = ВАК() 

566 ОЕАСТІѴАТЕ РОРЦР 

567 КЕТІЖЫ 

568 


Выбор позиции "Запрос" вертикального меню РЗ обеспечивает активизацию 
вертикального меню Р32, функции которого реализованы в процедуре Рор_Р32. 
Меню Р32 имеет пять позиций, три из которых (первая "Активизировать", третья 
"Изменить" и пятая "Создать") являются активными. При выборе первой или 
третьей позиции меню вызывается одна и та же процедура Рор_ Р321. Выбрав 
пятую позицию, пользователь получает возможность создать новый файл запроса. 
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Экран создания запроса на выборку данных вызывается командой СРЕАТЕ 
СШЕКѴ. 

569 РВОСЕОІЖЕ Рор_Р32 

570 ЕЮ САЗЕ 

571 САЗЕ ВАВ() = 1 А А Активизировать 

572 аа=1 

573 АСТ ГѴ АТЕ РОРЫР Р321 

574 САЗЕ ВАВ() = 3 АА Изменить 

575 аа =2 

576 АСТІѴАТЕ РОР11Р Р321 

577 САЗЕ ВАВ() = 5 АА Создать 

578 АСТІѴАТЕ ШІЫІХЛѴ Заѵеасг 

579 1івГѵа1=8РАСЕ(8) 

580 @ 10,19 іо 12,54 

581 @ 11,21 вау "Введите имя запроса " СЕТ Іівгѵаі 

582 ВЕЛО 

583 СВЕАТЕ ОІШВѴ Аіівіѵаі 

584 СЬЕАВ ОЕТЗ 

585 ОЕАСТІѴАТЕ Ѵ/ІЫІЮѴ/ Заѵевсг 

586 ЕЫІЮАЗЕ 

587 ЗЕТ МДЗЗЛСЕ ТО 

588 ОЕАСТІѴАТЕ РОРЕІР АА Деактивизация вертикального меню Р32 

589 ВЕТІЖЫ 

590 


Процедура Рор_Р321 позволяет активизировать или изменять структуру 
файла запроса на выборку данных (с расширением .цЬе). Функция РКОМРТ() 
возвращает имя файла запроса с маршрутом по директориям, выбранным из 
списка в окне вертикального меню Р321. Это имя присваивается переменной 
ІізіѵаІ, и затем, в зависимости от значения переменной аа (переданного из 
процедуры Рор__Р32), выполняется активизация файла запроса (аа=1) или выход 
на его модификацию (аа = 2). 

591 РВОСЕОІШЕ Рор Р321 

592 РАВАМЕТЕВ аа 

593 Іівіѵаі =РВОМРТ() 

594 ІЮ САЗЕ 

595 САЗЕ аа = 1 АА Активизировать 

596 ЗЕТ ѴІЕЧѴ ТО Аіівіѵаі 

597 САЗЕ аа = 2 АА Модифицировать 

598 МООІРѴ ѴІЕ>Ѵ Аіівіѵаі 

599 ЕЫІЮАЗЕ 

600 ЗЕТ МЕЗЗАСЕ ТО 

601 ОЕАСТІѴАТЕ РОРЫР 

602 ВЕТІШЫ 

В процедуре 5огі, вызываемой из процедуры Рор _ РЗ, с помощью 
выполнения макроопределения ТаЬзогі, считанного из файла Мас.кеу, обеспечива¬ 
ется выбор позиции Зогі 4а1аЬа$е оп (іеісі Іі$і вертикального меню. Это меню 
прикреплено к позиции Огдапіге горизонтального меню команды МОЭІРУ 
ЗТРІІСТІІКЕ создания/модификации структуры файла БД, что предоставляет 
пользователю возможность выполнить физическую сортировку файла. 

603 

604 РВОСЕОІШЕ ЗОВТ 

605 АСТІѴАТЕ \ѴІЫОО\Ѵ Заѵсвсг 

606 1с_вау ='Сортировка записей ’ 

607 ІЮ іпіо Ьох Ѵ/ІТН Ісвау 

608 ВЕ8ТОВЕ МАСВОЗ РВОМ МАС 

609 РЬАѴ МАСВО ТАВЗОВТ 
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610 мсюірѵ зпшстеікв 

611 ОЕАСГГѴАТЕ ѴІЫЕЮѴ Хаѵсвсг 

612 ЗЕТ МЕЗЗАСЕ ТО 

613 КЕТ1ЛШ 

614 


Процедура Рор_Р34 реализует функции вертикального меню Р34, 
обеспечивающие переход к первой (команда ѲО ТОР) или последней (команда 
СО ВОТТОМ) записи, а также поиск записи по ее физическому номеру (команда 
СО 2 П, где 2 П - номер записи, заданный пользователем). 

615 РКОСЕОЕІКЕ Рор_Р34 

616 ЕЮ САЗЕ 

617 САЗЕ ВАК() = 1 АА Первая запись 

618 АСТІѴАТЕ ШІЫЕЮѴѴ Заѵевсг 

619 ОО ТОР 

620 ОЕАСТІѴАТЕ \ѴІЫЕЮ\Ѵ Заѵевсг 

621 САЗЕ ВАК() = 3 АА Последняя запись 

622 АСТІѴАТЕ ѴУІЫООѴ/ Заѵевсг 

623 СО ВОТТОМ 

624 ОЕАСТІѴАТЕ ШІЫЕЮШ Заѵевсг 

625 САЗЕ ВАК() = 5 АА Запись N 

626 2Ы=0 

627 @ 13,66 СЕТ 2п РІСТІЖЕ "@2 99999 я 

628 КЕАЭ 

629 СО 20 

630 СЬЕАВ СЕТ5 

631 ЕЫЕ>СА5Е 

632 ЗЕТ МЕЗЗАСЕ ТО 

633 ОЕАСТІѴАТЕ РОРЕІР 

634 КЕТЕІКЫ 

635 


Процедура Рор_ Р4 реализует функции вертикального меню Р4. В 
вертикальном меню Р4 имеется пять позиций, три из которых (первая "Экранная 
форма", третья "Отчет", пятая "Марка") активные. Выбор любой из этих 
позиций активизирует вертикальное меню Р41, что приводит к вызову процедуры 
Рор_Р41. Процедуре Рор_Р41 из меню Р4 передается параметр ВВ, принимаю¬ 
щий значения 1, 2 или 3 в зависимости от выбора одной из активных позиций 
этого меню. Обычно при передаче в процедуру номера позиции вертикального 
меню используется функция ВАР(). В данном случае из меню Р4 передается 
параметр ЬЬ, поскольку функция ВАР() в дальнейшем используется для возврата 
номера позиции меню второго уровня Р41, а при реализации функций этого 
меню требуется использовать выбранное значение позиции меню первого уровня 
Р4 (см. процедуру Ргіпіоиі). 

636 РКОСЕОІЖЕ Рор Р4 

637 ЕЮ СА5Е 

638 СА8Е ВАК() = 1 АА Экранная форма 

639 ЬЬ =1 

640 АСТІѴАТЕ РОРІ1Р Р41 

641 СА5Е ВАК() = 3 АА Отчет 

642 ЬЬ~2 

643 АСТІѴАТЕ РОРЕІР Р41 

644 СА8Е ВАК.0 = 5 АА Марка 

645 ЬЬ=3 

646 АСТІѴАТЕ РОРЕІР Р41 

647 ЕЫІЮА8Е 

648 8ЕТ МЕ88АСЕ ТО 

649 ОЕАСТІѴАТЕ РОРЕІР 

650 КЕТЕІКЫ 



Процедура Рор_Р41 реализует функции вертикального меню Р41. К 
особенностям этой процедуры относится использование вложенных структур 
команд ЭО СА5Е...ЕЫОСА5Е: после ключевого слова САЗЕ размещается еще 
одна структура ЭО СА5Е...ЕЫРСА5Е. Вложенная система команд йО САЗЕ... 
ЕЫОСАЗЕ позволяет создать иерархическую систему разветвлений операций. В 
процедуре Рор_Р41 при выборе любой позиции вертикального меню Р41 
высвечивается вертикальное меню следующего уровня, позиции которого 
позволяют выполнить функции по разработке форм вывода данных. Например, 
при выборе позиции "Экранная форма" меню Р4 процедуре Рор_Р41 
передается параметр ЬЬ = 1 и выполняется вложенная команда йО САЗЕ... 
ЕЫЭСАЗЕ по реализации функций позиций меню Р41 "Вызвать" и "Изменить". 
При реализации функций позиции "Создать" вызывается окно Заѵезсг, в котором 
осуществляется ввод имени создаваемой экранной формы. Аналогичные операции 
выполняются и при разработке других форм вывода данных - отчетов и марок. 

651 

652 РКОСЕОІЖЕ Рор_Р41 

653 РАКАМЕТЕК ЬЬ ~ 

654 ЕЮ САЗЕ 

655 САЗЕ ЬЬ = 1 АА Экранная форма 

656 ІЮ САЗЕ 

657 САЗЕ ВАК() = 1 АА Подключить 

658 АСТІѴАТЕ РОРЕІР Р411 

659 САЗЕ ВАК() = 3 А А Создать 

660 АСТІѴАТЕ \ѴПЧЕЮ\Ѵ Заѵевсг 

661 И =5РАСЕ(8) 

662 @ 10,15 ТО 12,57 

663 @ 11,17 ЗАѴ "Введите имя экранной формы * СЕТ 11 

664 КЕАО 

665 СЕНАТЕ ЗСКЕЕЫ АН 

666 ОЕАСТІѴАТЕ ѴПЫЕЮѴѴ Заѵевсг 

667 САЗЕ ВАЕ() = 5 АА Изменить 

668 АСТІѴАТЕ РОРЕІР Р413 

669 ЕЫІЮАЗЕ 

670 САЗЕ ЬЬ = 2 АА Отчет 

671 ЕЮ САЗЕ 

672 САЗЕ ВАН() = 1 АА Подключить 

673 АСТІѴАТЕ РОРЕІР Р421 

674 САЗЕ ВАВ() = 3 АА Создать 

675 АСТІѴАТЕ ЛѴІЫЕЮШ Заѵевсг 

676 гг =5РАСЕ(8) 

677 @ 10,15 ТО 12,49 

678 @ 11,17 ЗАѴ "Введите имя отчета " СЕТ гг 

679 КЕАО 

680 СКЕАТЕ КЕРОКТ Агг 

681 СИНАЕ СЕТ5 

682 ОЕАСТІѴАТЕ \ѴІЫЕЮ\Ѵ Заѵевсг 

683 САЗЕ ВАК() = 5 А А Изменить 

684 АСТІѴАТЕ РОРЕІР Р423 

685 ЕЫІЮАЗЕ 

686 СИНАЕ СЕТ5 

687 САЗЕ ЬЬ = 3 АА марка 

688 ЕЮ САЗЕ 

689 САЗЕ ВАК() = 1 АА Подключить 

690 АСТІѴАТЕ РОРЕІР Р431 

691 САЗЕ ВАК() = 3 АА Создать 

692 АСТІѴАТЕ \ѴІЫЕЮ\Ѵ Заѵевсг 

693 11 =5РАСЕ(8) 

694 @ 10^21 ТО 12,56 

695 @ 11ДЗ ЗАѴ "Введите имя марки " СЕТ 11 
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696 ЕЕАЭ 

697 СКЕАТЕ ЬАВЕЬ АН 

698 ОЕАСГГѴАТЕ ЧѴШЕЮѴ Заѵеасг 

699 САЗЕ ВАЕ() = 5 ДА Изменить 

700 АСГ ГѴ АТЕ РОР11Р Р433 

701 ЕЫЕГСАЗЕ 

702 СЬЕАЕ СЕТ8 

703 ЕЫОСАЗЕ 

704 8ЕТ МЕ88АСЕ ТО 

705 СЬЕАК СЕТ8 

706 ОЕАСГГѴАТЕ РОР11Р 

707 НЕТІЖЫ 

708 


Процедура Рор_Р42 реализует функции вертикального меню Р42 по выводу 
предварительно созданного отчета на печать, в текстовый файл или на экран. 
Вызов процедуры и активизация меню Р42 осуществляются после выбора 
позиции "Вызвать" меню Р42 и выбора из высветившегося вертикального меню 
Р421 имени файла отчета. После этого высвечивается вертикальное меню Р421 
с тремя позициями "На печать", "В текстовый файл" и "На экран". 

После выбора позиции "На печать" меню Р421 в процедуре 
Рор_Р42 выполняются команды после опции САБЕ, соответствующей номеру 
этой позиции. Сначала высвечивается меню для установки параметров печати 
отчета: размеры страницы, отступ слева, интервал между строками, номер 
первой печатаемой страницы, тип шрифта и т.д. Эти операции реализуются в 
процедуре Ргі_тепи. Процедура Ргіпіоиі осуществляет вывод отчета или марки 
в зависимости от значения переданного параметра (ЬЬ = 2 - вывод отчета, ЬЬ = 3 
- вывод марки). После выбора позиции для вывода отчета в текстовый файл 
в окно с именем ТІіІе следует ввести имя файла и его расширение, а если 
нужно записать файл на другой диск или директорий, то нужно ввести имя 
диска и маршрут по директориям (например, С:\0ВА5Е\Р1_АМ\0ок1 .іхі). 

709 РЕОСЕОІЖЕ Рор Р42 

710 ЕЮ СА8Е 

711 СА8Е ВАЕ() = 3 АА Вывод на принтер 

712 ЕЮ Ргі тепи 

713 8ЕТ РЕЮТЕЕ ОЫ 

714 8ЕТ СОЫЗОЬЕ ОРР 

715 ЕЮ Ргіп(ои( 

716 8ЕТ РЕІ14ТЕЕ ОРР 

717 5ЕТ СОЫЗОЬЕ ОЫ 

718 САЗЕ ВАЕ() = 5 АА Вывод в текстовый файл 

719 апаѵег = ЗРАСЕ(8) 

720 АСТІѴАТЕ >ѴІЫЕЮ\Ѵ ТПІе 

721 @ 0,0 8АѴ ■-НАПРАВИТЬ ДОКУМЕНТ В ФАЙЛ-СОЬОЕ Ы/С* 

722 <§> 2,1 8АѴ "Введите имя файла : " СЕТ апэтѵег ; 

723 ѴАЬЮ "" <> ТЕІМ(апвѵег) ; 

724 МЕ38АСЕ "Имя файла состоит не более, чем из 8 символов" 

725 ЕЕАО 

726 ОЕАСТІѴАТЕ Ѵ/ІМЕЮѴ/ Тіііе 

727 ЗЕТ СОЫЗОЬЕ ОРР 

728 ЕЕРОЕТ РОЕМ АІівГѵаІ ТО РІЬЕ Дапашег 

729 СО ТОР 

730 ЗЕТ ОЕѴІСЕ ТО ЗСЕЕЕЫ 

731 ЗЕТ СОЫЗОЬЕ ОЫ 

732 САЗЕ ВАЕ() = 7 ДА Вывод на экран 

733 СЬЕАЕ 

734 рІеп^іЬ = _р1епв(Ь 

735 гтаг^іп = _гтаг^іп | 4. 

736 рІеп^іЬ = 25 
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737 _гтаг&іп ■ 80 

738 Ьо РгіпІоиІ 

739 СЬЕАК 

740 _р1еп((Ь - р1еп&(Ь 

741 _гт«Г(іп - гтаг^ш 

742 СО ТОР 

743 ЕЫОСА8В 

744 ОЕАСГГѴАТЕ РОТОР 

745 КЕТОНЫ 

746 


Процедура Ріі.тепи осуществляет перед печатью отчета установку 
параметров страницы и опций печати. Пользователь задает левую и правую 
границы печати, количество строк на странице, расстояние между строками, с 
какой страницы начать печать и на какой закончить, число копий и т.д. 

747 РКОСЕОІЖЕ Ргішепч 

748 терпит * 'Введите число* 

749 т*8_1оде « 'Введите V или Ы" 

750 твв_епит = Нажмите клавишу 'Пробел* для выбора других опций* 

751 Шішеі - 0 

752 1таг(іо - 0 

753 гтагдоп - 80 

754 іпбепі = 4 

755 рІеп^іЬ - 66 

756 8ТОКЕ 1 ТО рерасіпв, рЬра^е, рсоріеа 

757 рераде = 9999 

758 рс^ссі --ЫОЫВ ' 

759 8ТОКЕ .Р. ТО рягай, ряиаійу 

760 ррі(сЬ -'РІСА ' 

761 АСГІѴАТЕ >Ѵ1ЫЕЮ\Ѵ МргіпС 

762 СЬЕАК 

763 @ 2, 1 8АУ "Параметры страницы” 

764 @ 3, 1 8АУ " " ■ ■ ■ ■ 

765 <$ 4, 1 5АУ -Отступ слева ■ ОЕТ ІоИасІ РІСГОКЕ ”99” 

766 @ 5, 1 8АѴ "Левая граница * СЕТ Ішагвіп РІСГОКЕ *99" 

767 @ 6, 1 8АѴ 'Правая граница ' СЕТ гтаг^іп РІСГОКЕ "999” 

768 @ 7, 1 8АУ 'Абзац ' СЕТ ішіепі РІСГОКЕ "99" 

769 <8 8, 1 8АѴ "Длина страницы ' СЕТ р1еп*1Ь РІСГОКЕ "99" 

770 @ 9,1 5АУ -Расс, между строк." СЕТ рарасіп В РІСГОКЕ "9” КАЫСЕ 1,3 

771 @ 206 8АѴ -Установки печати- 

772 @ 306 8АѴ ■ ■ . . * 

773 @ 406 8АѴ Начать печать со стрХ * СЕТ рЬраде РІСГОКЕ "999" 

774 @ 506 8АѴ -Закончить на стр. N ' СЕТ рера в с РІСГОКЕ "9999" 

775 @ 606 8АУ -Число копий "СЕТ рсоріе* РІСГОКЕ "999" 

776 @ 106 8АѴ "Прогон бумаги " СЕТ рср& ; 

777 РІСГОКЕ ”@М ВЕРОКЕЛРТЕКЛОТН^ОЫЕ" МЕ55АСЕ та^етт» 

778 @ 8 06 8АѴ "Ждать между страницами ” ОЕТ рѵаіс РІСГОКЕ "У” 

779 @ 906 8АѴ Тип шрифта " СЕТ рріісЬ ; 

780 РІСГОКЕ ”@М ОЕРАОІЛ',РІСА,ЕЕГГЕДОЫОВЫ8ЕО" МЕ88АСЕ ш^ епит 

781 @ 1006 8АѴ -Качественная печать " СЕТ рциаіііу РІСГОКЕ "У” 

782 @ 12,155АУ "Введите параметры и нажмите клавишу Р^Оп для сохранения” 

783КЕАО 

784 ОЕАСГГѴАТЕ ШІЫІХЛѴ Мргіпі 

785 _р1оГГаеІ = ІоІГаеІ 

786 _1таг&іп = Ітаг&іп 

787 _гтаг^іп = гтаг&іп 

788 _іп6епІ = ішкп( 

789 _р1еп^1Ь = рІеп^іЬ , 

790 _рсрасіп§ = рфасіпв 
791_рЬра 8 е = рЬра В е 
7^2 _рера 8 е = рера 8 е 
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793 _рсорі« = рсоріес 

794 _реуссІ = ре)ес( 

795 _рѵаі( - рѵаіі 

796 _рріІсЬ = рріісЬ 

797 ^иаіііу = рциаіііу 
796 ЕЕТЦЕЫ 

799 


Процедура Ргіпіои* вызывается из процедуры Рор_Р42 и подключает вывод 
отчета или марки в зависимости от значения переменной ЬЬ. 

800 РКОСЕОІЖЕ Ргіпіоиі 

801 IX) СА8Е 

802 СА5Е ЬЬ =2 

803 ЕЕРОЕТ РОЕМ Аіішіѵаі 

804 СА5Е ЬЬ = 3 

805 ЬЛВЕЬ РОЕМ Аіівіѵаі 

806 ЕЫОСА5Е 

807 СЬЕАЕ 

808 СО ТОР 

809 ЕЕТІЖЫ 

810 


Процедура Рор_Р411 активизирует вертикальное меню Р411, в котором 
высвечивается список ранее созданных файлов экранных форм (с расширением 
.іті). Функция РКОМРТ() возвращает имя файла экранной формы, выбранного 
из списка с помощью вертикального меню Р411, с указанием диска и маршрута 
по директориям. Переменной ІізіѵаІ присваивается значение функции РКОМРТ() 
и затем командой 5ЕТ РСЖМАТ ТО &Ііз*ѵаІ активизируется файл экранной 
формы. 

811 РЕОСЕЭІЖЕ Рор_Р411 

812 Іісіѵаі =РЕОМРТ() 

813 8ЕТ ЕОЕМАТ ТО Аііііѵаі АА Подключение файла экранной формы 

814 Гг~1ів(ѵаі 

815 8ЕТ МЕ88ЛСЕ ТО 

816 ОЕАСТІѴАТЕ РОРЫР АА Р411 

817 ЕЕТІІЕЫ 

818 


Процедура Рор_Р413 также активизирует вертикальное меню Р413, в 
котором высвечивается список файлов созданных экранных форм (с расширением 
.зсг). После выбора пользователем требуемого файла экранной формы функция 
РКОМРТ0 возвращает имя файла с маршрутом по директориям. Переменной 
ІізіѵаІ присваивается значение функции РКОМРТ() и затем командой МОРІРѴ 
5С&ЕЕЫ &ІІ5ІѵаІ вызывается экран модификации данной формы. 

Следующие процедуры с именами Рор_Р421, Рор_Р423, Рор_Р431 и 
Рор_Р433 однотипны по своим функциям. Они вызываются при активизации 
вертикальных окон, высвечивающих списки файлов отчетов и марок с расширени¬ 
ями соответственно Агд, .ігт, .ІЬд и .ІЫ. 

819 РЕОСЕОУЕЕ Рор_Р413 

820 1іс(ѵа1 =РЕОМРТ()"" 

821 МОРІРѴ 8СЕЕЕЫ А1і$(ѵа1 АА Модификация структуры экранной формы 

822 8ЕТ МЕ88АСЕ ТО 

823 ОЕАСТІѴАТЕ РОРУР АА Р413 

824 ЕЕТУЕЫ 

825 

826 РЕОСЕОУЕЕ Рор_Р421 

827 1іс(ѵа1 =РЕОМРТ() 

828 АСТІѴАТЕ РОРУР Р42 
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829 ЗЕТ МЕЗЗАСЕ ТО 

830 ОЕАСТІѴАТЕ РОР11Р АА Р421 

831 КЕТШМ 

832 

833 РКОСЕОІШЕ Рор_Р423 

834 1і>(ѵа1 =РКОМРТ() 

835 МООІРѴ КЕРОКТ Діісіѵаі ДА Моднфнцня структуры отчета 

836 ЗЕТ МЕЗЗАСЕ ТО 

837 ОЕАСТІѴАТЕ РОРІ1Р АА Р423 

838 КЕТІЛМ 

839 

840 РКОСЕОІЖЕ Рор_Р431 

841 1і<(ѵа1 =РКОМРТ() _ 

842 АСТІѴАТВ РОР11Р Р42 

843 ЗЕТ МЕЗЗАСЕ ТО 

844 ОЕАСТГѴАТЕ РОРЧР ДА Р431 

845 КЕТІЖЫ 

846 

847 РКОСЕОІЖЕ Рор_Р433 

848 ІівСѵаІ =РКОМРТ()~ 

849 МООІРѴ ЬАВЕЬ ДІівГѵаІ АА Модифицировать файл марки 

850 ЗЕТ МЕЗЗАСЕ ТО 

851 ОЕАСТГѴАТЕ РОР11Р ДА Р433 

852 КЕТІЖИ 

853 


Процедура Рор _ Р5 реализует функции позиций вертикального меню Р5, 
прикрепленного к позиции "Сервис" горизонтального меню ©1. Меню Р5 
позволяет устанавливать некоторые параметры системы 4ВА5Е IV (позиция 
"Установка параметров 4ВА5Е IV"); осуществлять экспорт и импорт файлов 
(позиции "Экспорт", "Импорт"); выполнять копирование, удаление и переимено¬ 
вание файлов (позиции "Копировать", "Удалить", "Переименовать"); вызывать 
текстовый редактор (позиция "Редактор текста"); вычислять свободную 
оперативную память (позиция "Память"). 

При выборе позиции "Редактор текста" вызывается простой и удобный 
текстовый редактор ЫоНоп Есіііог (версия 3.0, 1987 г.), входящий в состав 

популярных утилит Питера Нортона (пакет ЫоИоп ІЖІііез). Предполагается, что 
файл вызова редактора пе.сот находится на диске С: в директории N11 
(С:\МІІ\ЫЕ). 

Особенностью данной процедуры является использование некоторых команд 
005. Например, для копирования файлов используется команда 005 СОРУ, 
которая вызывается командой языка СІВА5Е IV "!": !СОРѴ &со &ск, где со - 
переменная с именем исходного копируемого файла (файла - источника); ск - 
переменная с именем выходного файла (файла-мишени), в который будет 
скопирован файл-источник. 

854 РКОСЕОІЖЕ Рор_Р5 

855 ГЮ САЗЕ 

856 САЗЕ ВАК() = 1 

857 АСТІѴАТЕ Ѵ/ІЫЕЮ\Ѵ Заѵессг 

858 ЗЕТ 

859 ОЕАСТІѴАТЕ ШІИООШ Заѵессг 

860 САЗЕ ВАК() = 3 ДА Экспорт 

861 АСТІѴАТЕ РОРІ1Р Р52 

862 САЗЕ ВАК() = 4 ДА Импорт 

863 АСТІѴАТЕ РОРІІР Р53 

864 САЗЕ ВАК() = 6 ДА Копировать 

865 АСТІѴАТЕ ШІЫІХНѴ Заѵессг 

866 со =ЗРАСЕ(60) 

867 ск =ЗРАСЕ(60) 
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868 @ 8,1 (о 10,79 соіог Ь/п 

869 9,2 ЗА У ■ Откуда копировать информацию 

870 СЕТ со РІСТІЖЕ "@843 * 

871 @ 11,1 іо 13,79 соіог Ь/п 

872 @ 12,2 ЗАѴ " Куда копировать а ; 

873 СЕТ ск РІСТІЖЕ "@543 ■ 

874 К ЕЛО 

875 !СОРѴ Лео Дек ДД Команда 1X75 - копирование 

876 СЬЕАК СЕТЗ 

877 ОЕАСТІѴАТЕ \Ѵ1ЫІХ»Ѵ Заѵевег 

878 СЬЕЛК 

879 САЗЕ ВАК() = 8 ДД Удалить 

880 АСТІѴАТЕ ШІИОО\Ѵ Заѵеасг 

881 ОЬ =8РАСЕ(60) 

882 @ 8 Л (о 10,78 соіог Ь/п 

883 @ 93 8АУ * Введите директорий и имя файла для удаления 

884 СЕТ 61 РІСТІЖЕ "@827 * 

885 КЕАО 

886 !ОЕЬ ДЭЬ ДД Команда 1Х)8 - удаление 

887 СЬЕАК СЕТЗ 

888 ОЕАСТІѴАТЕ ШИЧІХПѴ Заѵевег 

889 СЬЕАК 

890 САЗЕ ВАК() = 10 ДД переименовать 

891 АСТІѴАТЕ ѴѴІЫООѴѴ Заѵевег 

892 г* =ЗРАСЕ(60) 

893 гп =5РАСЕ(60) 

894 @ 8,1 (о 10,79 соіог Ь/п 

895 @ 9,2 ЗАУ " Какой файл переименовать ? 

896 СЕТ г» РІСТІЖЕ "@846 ■ 

897 @11,1 Ю 13,79 соіог Ь/п 

898 @ 12,2 ЗАУ " Во что переименовывать ? 

899 СЕТ гп РІСТІЖЕ "@546 " 

900 К ЕЛО 

901 КЕЫЛМЕ АК5 ТО АКИ ДД Переименовать файл 

902 СЬЕАК СЕТЗ 

903 ОЕАСТІѴАТЕ >ѴІЫІХ)\Ѵ Заѵевег 

904 САЗЕ ВАК () = 12 ДА Редактор текста 

905 !С: 

906 !СО СДИІІ ДД Запуск редактора Ыогіоп Ебііог, 

907 !ЫЕ ДД расположенного в директории С ДИ 11 

908 САЗЕ ВАК() = 14 ДД Память 

909 АСТІѴАТЕ \ѴІЫСЮ>Ѵ Заѵевег 

910 РК -"Свободная оперативная память составляет - "; 

911 +ЬТКІМ(8ТК(МЕМОКУ ()))+" Кбайт." 

912 @ 10,14 8АУ РК 

913 ЗЕТ МЕ53АСЕ ТО "Для выхода в главк, меню нажмите любую клавишу" 

914 ЗЕТ СОИЗОЕЕ ОРР 

915 \ѴАГГ 

916 ЗЕТ СОИЗОЬЕ ОН 

917 ОЕАСТІѴАТЕ ШІЫСЮѴ/ Заѵеасг 

918 ЕЫОСАЗВ 

919 ЗЕТ МЕЗЗАСЕ ТО 

920 ОЕАСТІѴАТЕ РОРЬІР ДД Р5 

921 КЕПЖЫ 

922 


Процедура Рор_Р52 реализует функции вертикального меню Р52, которое 
вызывается после выбора позиции "Экспорт" вертикального меню Р5, для 
обеспечения экспорта активного файла БД в файлы формата РР5, сіВАЗЕ II, 
Ргатеѵѵогк II, РарігіРіІе. 
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923 РКОСЕОІГКЕ Рор_Р52 

924 ІЮ САЗЕ 

925 САЗЕ ВАК() = 1 АА РРЗ-файл 

926 АСГГѴ АТЕ ФМЕЮФ Заѵевсг 

927 1с му =*Экспорт записей в файл ѴРРЗ’ 

928 ЕЮ іпІоЬох ШГГН Ісвау 

929 Ір=*РР5" 

930 ЕЮ Ргос52 ШГГН ТР 

931 ОЕАСТГѴАТЕ ШІМЮѴ/ Заѵевсг 

932 САЗЕ ВАК() = 3 АА <ШАЗЕІІ-файл 

933 АСГІѴАТЕ Ш1ЫЕЮѴѴ Заѵевсг 

934 Іс_вау =, Экспорт записей в файл *.<ША5ЕІГ 

935 ЕЮ іпіо Ьох >ѴГГН Ісвау 

936 Ір=Ч>ВА5ЕІГ 

937 ЕЮ Ргос52 ѴѴГГН ТР 

938 ОЕАСТІѴАТЕ Ѵ/ІЫООѴ/ Заѵевсг 

939 САЗЕ ВАК() = 5 АА Р\Ѵ2-файл 

940 АСГІѴАТЕ \ѴІЫЕЮШ Заѵевсг 

941 Ісвау =’Экспорт записей в файл •.РЛѴ2’ 

942 ЕЮ ІпІоЬох ШГГН Іс вау 

943 Ір ="Р\Ѵ2" 

944 ЕЮ Ргос52 \ѴГГН ТР 

945 ОЕАСТІѴАТЕ \ѴІЖЮ\Ѵ Заѵевсг 

946 САЗЕ ВАК() = 7 АА КРО-файл 

947 АСГІѴАТЕ \ѴІИЕЮ\Ѵ Заѵевсг 

948 1с_вау =*Экспорт записей в файл ѴКРО’ 

949 ЕЮ іпіо Ьох \ѴГГН Іс вау 

950 Ір="КРО" 

951 ЕЮ Ргос52 ШІТН ТР 

952 ОЕАСТІѴАТЕ \ѴІИЕЮ\Ѵ Заѵевсг 

953 ЕЫЕЮАЗЕ 

954 ЗЕТ МЕЗЗАСЕ ТО 

955 ОЕАСТІѴАТЕ РОР11Р АА Р52 

956 КЕТІЖИ 

957 


Процедура Ргос52 вызывается из процедуры Рор_Р52 и выполняет 
операцию экспорта файла БД в файл формата, указанного в переменной ір, 
.значение которой передается из процедуры Рор_Р52. 

958 РКОСЕОШІЕ Ргос52 

959 РАКАМЕТЕК ТР 

960 ех =ЗРАСЕ(8) 

961 @ 10,4 ТО 12,76 

962 @ 11,7 ЗАѴ " Имя файла, худа будут экспортированы данные " СЕТ ЕХ 

963 КЕАО 

964 ЗЕТ ТАЬК ОЫ 

965 ЕХРОКТ ТО Аех ТУРЕ АГр АА Экспорт файла 

966 ЗЕТ ТАЬК ОРР 

967 СЬЕАК СЕТ8 

968 КЕГЕІКЫ 

969 


Процедура Рор_Р53 вызывается при активизации вертикального меню Р53 
и обеспечивает импорт файлов формата РР5, 4ВА5Е II, КарійРіІе, Ргатеѵѵогк II, 
І_о*іі5 1-2-3 в файл БД СІВА5Е IV. 

970 РКОСЕОІЖЕ Рор_Р53 

971 ОО САЗЕ 

972 САЗЕ ВАК() = 1 АА Формат РРЗ 

973 «="•" 

974 ір=-РР5" 

975 ЕЮ Ргос531 ШГГН И.ір 

976 САЗЕ ВАК() = 3 АА Формат йВАЗЕ II 

977 ІІ="*.ОВ2" 
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978 (р="ОВА8ЕІІ" 

979 ЕЮ Ргос531 ^ГГН М,1р 

1 980 СА8Е ВАК() = 5 АА Формат КРО 

981 М="*.КРО* 

982 Ір="КРО" 

983 ЕЮ Ргос531 9/ГГН 11,ір 

984 СА8Е ВАК() = 7 АА Формат Ргатеѵогк II 

985 М="МПѴ2* 

986 Гр="Р\Ѵ2" 

987 ІЮ Ргос531 1ѴІТН И,1р 

988 СА8Е ВАК() = 9 АА Формат \ѴК1 

989 И- В *.ѴК1 В 

990 Гр=*>ѴКГ 

991 ЕЮ Ргос531 1ѴГГН Н,1р 

992 ЕЫІЗСА8Е 

993 8ЕТ МЕ88АСЕ ТО 

994 ОЕАСТІѴАТЕ РОРЫР АА Р53 

995 КЕШКИ 

996 


Процедура Ргос531 вызывается из процедуры Рор_Р53 и выполняет 
операции по определению и активизации вертикального меню Р531, высвечиваю* 
щего список файлов того типа, который передается с переменной Н, для 
обеспечения операций экспорта или импорта. 

997 РКОСЕОІШЕ Ргос531 

998 РАКАМЕТЕК ГГ.Ір 

999 ОЕРІНЕ РОР11Р Р531 РКОМ 10,55 ТО 20,70 РКОМРТ РІЬЕЗ ЫКЕ АРР 

1000 ОН ЗЕЬЕСГЮН РОРЕГР Р531 ЕЮ Рор Р531 \ѴГГН Ір 

1001 АСПѴАТЕ РОР11Р Р531 

1002 КЕШКИ 

1003 


Процедура Рор_Р531 реализует функции вертикального меню Р531, которое 
определяется и активизируется в процедуре РгосБЗІ. 

1004 РКОСЕОІШЕ Рор_Р531 

1005 РАКАМЕТЕК ТР 

1006 1іа(ѵа1 = РКОМРТ0 

1007 ІР .ЫОТ. -РР8- $ ТР 

1008 1іа(ѵа1 =ЕЕРТ(’А1івГѵа1 , ЛТ(Ѵ, , АН*еѵаГ)-1) 

1009 ЕНОІР 

1010 АСГІѴАТЕ ЧѴІИЕЮѴ/ 8аѵс*сг 

1011 1с_сау =*Импорт записей из файла ’+ІівіѵаІ 

1012 ЕЮ іпіо Ьох ^ГГН 1с аау 

1013 8ЕТ ТАЁК ОН 

1014 ІМРОКТ РКОМ АІіМѵаІ ТУРЕ АТР 

1015 8ЕТ ТАЬК ОРР 

1016 ОЕАСТІѴАТЕ \ѴІИЕЮ9/ Заѵсасг 

1017 8ЕТ МЕ88АСЕ ТО 

1018 ОЕАСТІѴАТЕ РОРЕІР 

1019 КЕШКИ 

1020 


Процедура Рор_Р6 реализует функции вертикального меню Р6, обеспечи¬ 
вающие выход из программы Зегѵісе в УЦ 4ВА5Е IV (командой КЕТІІКЫ ТО 
МАЗТЕК) или в РОЗ (командой ОШТ). 

1021 РКОСЕОЕІКЕ Рор Рб 

1022 ЕЮ СА8Е 

1023 СА8Е ВАК() = 1 АА Выход в 4ВА8Е IV 

1024 АСГІѴАТЕ 1ѴІНІЮ1Ѵ Заѵехсг 

1025 ОЕАСТІѴАТЕ МЕН1Г 

1026 ОЕАСТІѴАТЕ ШІИЕЮѴ/ 8аѵессг 
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1027 СА8Е ВАК() = 3 ДА Выход в ЕЮ5 

1028 СШ8Е ОАТАВА8Е8 

1029 оілт 

1030 ЕЫОСА8Е 

1031 8ЕТ МЕ88АСЕ ТО 

1032 ОЕАСГІѴАТЕ РОРІЖ 

1033 кетіжы 

1034 


Процедура Соіог устанавливает расцветку различных частей экрана: текст 
на экране выводится ярко белым цветом на черном фоне, названия позиций 
меню и сообщений - ярко белым цветом на розовом фоне, заголовки - ярко 
белым цветом на черном фоне, подсветка курсора - желтым цветом на красном 
фоне, рамки меню - ярко белым цветом на розовом фоне, текст в строке 
состояния системы - черным цветом на белом фоне, поля записей файлов БД 
- ярко голубым цветом на синем фоне. 

1035 РКОСЕОІЖЕ СОІХЖ 

1036 ІР І8СОІХЖ() 

1037 8ЕТ СОЬОК ОР ІЧОКМАЬ ТО \Ѵ +/Ы А А Техет на экране 

1038 8ЕТ СОІХЖ ОР МЕ88АСЕ8 ТО +/ВК АА Меню н подсказки 

1039 8ЕТ СОІХЖ ОР ТПЪЕ8 ТО +/Ы АА Заголовки 

1040 8ЕТ СОБОК ОР НІСНЫСНТ ТО СЕ+/К ДА Курсор 

1041 8ЕТ СОІХЖ ОР ВОХ ТО \Ѵ+/ВВ ДА Цвет рамки 

1042 8ЕТ СОІХЖ ОР ІЫРОКМАТІОЫ ТО 1Ч/\Ѵ АА Строка состоян. системы 

1043 8ЕТ СОІХЖ ОР РІЕБ08 ТО ВО+/В ДА Поля файла БД 

1044 ЕЫЭІР 

1045 КЕТІЖЫ 

1046 


Процедура ІпІо_Вох высвечивает в верхней левой части экрана сообщение 
о выполняемом действии. Например, при переиндексации файла БД командами 
? Іс_зау и ? КЕРЫСАТЕ ("-",ЬЕЫ(Іс _ $ау)) на экран выводится сообщение 
"Переиндексация базы данных..." и на следующей строке подчеркивается по всей 
его длине. 

1047 РКОСЕОІЖЕ ІпГо Вох 

1048 РАЕАМЕТЕК8 Іс вау 

1049 ? 1с аау 

1050 ? КЁРБІСАТЕ("--,ЬЕЫ(1с_8ау)) 

1051 ? 

1052 КЕТ1ЖЫ 

1053 


Процедура Раизе активизируется при возникновении ошибки в программе. 
Назначение вызова этой процедура осуществляется командой ОЫ Е&КСЖ в 
главной процедуре. Имя программного модуля (процедуры) с номером строки, 
в которой возникла ошибка, передается в процедуру как параметр. Эти данные 
записываются в переменную Іс_т$д. В результате активизируется окно Раизе и 
в нем высвечивается сообщение типа: 

Произошла ошибка !!! - Сообщение: Рііе 4оез по1- ехізі 

Процедура: Зегѵісе Строка: 30 

Для продолжения нажмите любую клавишу... 

1054 РКОСЕОІЖЕ Раисе 

1055 РАКЛМЕТЕК 1с шс 8 

1056 ІР ТуРЕ( в 1с_тессаве в )=-и- 

1057 8п_сггог=ЁкКОК() 

1058 ЕЫОІР 

1059 1с_тсв = 1с_т$в 

1060 1с_ор(іоп =4)’ 
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1061 АСТІѴАТЕ ШШЕЮѴ/ Раиве 

1062 

1063 ІР ^п сггог > 0 

1064 ІРТУРЕ(“1с_ше88а В е")="ІІ" 

1065 @ ОД 5АѴ; 

1066 [Произошла ошибка !!! - Сообщение: ]+МЕ85АСЕ() 

1067 ЕС5Е 

1068 <§> ОД 8АУ [Ошибка # ]+1с_те88а^е 

1069 ЕЫОІР 

1070 ЕЫОІР 

1071 

1072 @ 1,1 8АУ 1с_т8в 

1073 IX) ВЕСЕ 

1074 ѴАГГ ■ Для продолжения нажмите любую клавишу...” 

1075 ОЕАСТГѴАТЕ ^ІЫІХ)\Ѵ Ра иве 

1076 КЕТІЖЫ 

1077 


Процедура НІрзсг вызывается нажатием клавиши Р1 (назначение вызова 
выполняется в главной процедуре) и позволяет вывести на экран шесть форм 
справочной информации, которые поясняют функции позиций вертикальных меню 
первого уровня, прикрепляемых к позициям основного (горизонтального) меню. 
Формы справочной информации высвечиваются в окне Неірзсг. Команда 
хх=1ЫКЕУ(0), следующая после команд @...5АѴ вывода справочной информации, 
удерживает ее на экране до последующего нажатия пользователем любой 
клавиши. 


1078 РКОСЕОІЖЕ Нірвсг 

1079 АСТІѴАТЕ \ѴІЫЕЮ\Ѵ Неірвсг 

1080 АСТІѴАТЕ 8СКЕЕК 

1081 @ 24,20 8АУ “Для продолжения нажмите любую клавишу... 

1082 хх=ШКЕУ() 


1083 @4,2 

1084 @5,2 

1085 @6,2 

1086 @7,2 

1087 @ 8,2 

1088 @9,2 

1089 @10,2 5АУ" 

1090 @ ІІД 5АУ ” 

1091 @12Д ХАУ" 

1092 @13,2 8АУ- 

1093 @14,2 5АУ 


8АУ ' 
5АУ ' 
ХАУ 
ХАУ 
ХАУ 
ХАУ 1 


Открыть 

Закрыть 


Создать 

Изменить 


Скопировать 


‘ СОСОК СК+/С + 
■СОСОК СК+/С + 
"СОСОК СК+/С + 
■СОСОК СК+/С + 

■ СОСОК. СК+/С + 
■СОСОК ОК+/С + 
"СОСОК СК+/С + 
■СОСОК СК+/С + 
■СОСОК СК+/С + 
■СОСОК ОК+/С + 
■СОСОК ОК+/С + 

- позволяет выбрать БД и открыть ее ■ 


Перенндексировать 


1094 @ 4,27 ХАУ "Открыть 

1095 @ 5,27 ХАУ ■ 

1096 @ 6,27 ХАУ "Закрыть - закрывает активный файл БД " 

1097 @7,27 ХАУ" 

1098 @ 8,27 ХАУ “Изменить - изменяет структуру активной БД “ 

1099 @ 9,27 ХАУ ■ 

1100 @ 10,27 ХАУ “Перенндексировать - производит переопределение” 

1101 @ 11,27 ХАУ ' структуры индексного файла" 

1102 @ 12,27 ХАУ " в соответствии с изменены-" 

1103 @ 13,27 ХАУ " ямн в индексных полях " 

1104 @ 14,27 ХАУ " 

1105 @ 15,27 ХАУ "Скопировать - создаст новый файл БД со структурой" 

1106 @ 16,27 ХАУ ■ активного в данный момент файла БД” 

1107 хх =ІЫКЕУ (0) 

1108 @ 4Д ХАУ ' 


1109 @ 5Д 

1110 @ 6Д 

1111 @ 7Д 

1112 @ 8Д 

1113 @ 9Д 


ХАУ 
ХАУ ' 
ХАУ ' 
ХАУ 
ХАУ ' 


Редактировать 


Добавить 


Удалить 


■СОСОК СК+/С + 
•СОСОК ОК+/С + 
■ СОСОК СК+/С + 
■СОСОК ОК+/С + 
■СОСОК СК+/С + 
■СОСОК ОК+/С + 
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1114 @ 10,2 ЗАУ ‘ |- 

1115 @112 ЗАУ * 

1116 @122 ЗАУ* 

1117 @132 ЗАУ " 

1118 @ 142 ЗАУ • 


Просмотреть 


■ СОЬОК СК+/С + 
■С0Ь0КСК+/0 + 
• СОЬОК ОК+/С + 


1117 @ 13,2 ЗАУ • СОЬОК В/В 

1118 @ 14,2 ЗАУ " ■ СОЬОК В/В 

1119 @ 427 ЗАУ ‘Редактировать - позволяет изменять содержимое 

1120 @ 527 ЗАУ * записей, высвечиваемых по одной " 

1121 @ 6,27 ЗАУ " (форма Е<Ш) или в виде списка " 

1122 @7,27 ЗАѴ (Вгоѵве таблица) 

1123 @827 ЗАУ " 

1124 @ 9,27 ЗАУ -Добавить - добавляет в файл БД новые записи ■ 

1125 @ 1027 ЗАУ " 

1126 @ 11,27 ЗАУ "Удалить - помечает для удаления, удаляет * 

1127 @ 1227 ЗАУ ” физически или восстанавливает - 

1128 @ 13,27 ЗАУ ” помеченные для удаления записи - 

1129 @ 1427 ЗАУ ■ 

ИЗО @ 1527 ЗАУ -Просмотреть - высвечивает содержимое файла БД 

1131 @ 1627 ЗАУ • 

1132 хх=ІЫКЕУ(0) 

1133 @42 ЗАУ-і -" СОЬОК СК+/С + 

1134 @52 ЗАУ " Поиск ■ СОЬОК СК+/С+ 

1135 @62 ЗАУ"- " СОЬОК СК+/С + 

1136 @72 ЗАУ" Запрос ■ СОЬОК СК+/0 + 

1137 @82 ЗАУ"- " СОЬОК СК+/0 + 

1138 @92 ЗАУ Сортировка ' СОЬОК СК+/С + 

1139 @ 102 ЗАУ "- - СОЬОК СК+/С + 

1140 @112 ЗАУ" Запись N ■ СОЬОК СК+/С + 

1141 @ 122 ЗАУ -I- ■ СОЬОК ОК+/С + 

1142 @ 132 ЗАУ " - СОЬОК В/В 

1143 @142 ЗАУ -СОЬОК В/В 

1144 @ 427 ЗАУ -Поиск - осуществляет поиск записи 

1145 @ 527 ЗАУ " по заданному условию 

1146 @627 ЗАУ 

1147 @ 727 ЗАУ "Запрос - позволяет создавать, подключать " 

1148 @ 827 ЗАУ " или модифицировать запросы на - 

1149 @ 927 ЗАУ " выборку данных из файлов БД - 

1150 @ 1027 ЗАУ " 

1151 @ 1127 ЗАУ "Сортировка - сортирует записи в возрастающей " 

1152 @ 1227 ЗАУ " или убывающей последовательности " 

1153 @ 1327 ЗАУ " по указанным полям - 

1154 @ 1427 ЗАУ " 

1155 @ 1527 ЗАУ "Запись N - переход к первой, последней записи " 


-- СОЬОК СК+/С + 

: - СОЬОК ОК+/0+ 

- - СОЬОК СК+/С + 

с ' СОЬОК СК+/0 + 

- ■ СОЬОК ОК+/С + 

гровка - СОЬОК СК +/С + 

- ■ СОЬОК ОК+/С + 

ь N - СОЬОК СК+/С + 

- ■ СОЬОК СК+/С + 

- СОЬОК В/В 
• СОЬОК В/В 

- осуществляет поиск записи 
по заданному условию 

- позволяет создавать, подключать - 
или модифицировать запросы на - 
выборку данных из файлов ЕД * 


1156 @ 1627 ЗАУ • 

1157 хх=ІЫКЕУ(0) 

1158 @42 ЗАУ "г 

1159 @52 ЗАУ " 

1160 @ 62 ЗАУ ’ - 

1161 @72 ЗАУ " 

1162 @ 82 ЗАУ " - 

1163 @92 ЗАУ " 

1164 @102 5АУ"'- 

1165 @112 5АУ “ 

1166 @122 5АУ 

1167 @132 ЗАУ " 

1168 @ 142 ЗЛУ - 


N - переход к первой, последней записи 
или к записи по указанному номеру - 


Экранная форма 


■СОЬОК СК+/С + 

■ СОЬОК СК+/С + 
■СОЬОК ОК+/С + 
■СОЬОК СК+/0 + 
“СОЬОК СК+/С + 
■СОЬОК СК+/С + 

■ СОЬОК СК+/С + 


1165 @ 112 ЗАУ ■ ■ СОЬОК В/В 

1166 @122 ЗАУ -СОЬОК В/В 

1167 @ 132 ЗАУ ■ • СОЬОК В/В 

1168 @ 142 ЗАУ ■ ■ СОЬОК В/В 

1169 @ 427 ЗАУ -Экранная форма - предоставляет возможность " 

1170 @ 527 ЗАУ - пользователю разрабатывать, ' 

1171 @ 627 ЗАУ ” модифицировать или подлючать " 

1172 @ 727 ЗАУ " созданные формы для ввода и - 

1173 @ 827 ЗАУ - вывода данных на экран 

1174 @927 ЗАУ 

1175 @ 1027 ЗАУ * 

1176 @ 1127 ЗАУ "Отчет/Марка - создает или изменяет структуру- 

1177 @ 1227 ЗАУ " отчета/марки, а также выводит" 

1178 @ 1327 ЗАУ " на печать, экран или в тек сто- - 

1179 @ 1427 ЗАУ " вый файл сгенернр. отчет/марку " 
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1180 @ 15,27 СЬЕАК ТО 18,76 
1181п=ІИКЕѴ(0) 

1182 @4,2 5АѴ 
8АѴ 
8АѴ 
ЗЛУ 
ЗЛУ 
5АУ 


1183 @5,2 

1184 @6Д 

1185 @ 7,2 

1186 @ ВЛ 

1187 @ 9,2 

1188 @ 10,2 8АѴ ■ 

1189 @11,2 ЗЛУ " 

1190 @ 12Д 5АУ " 

1191 @ ІЗД 8АУ "| 

1192 @ 14,2 8АУ " 

1193 @15,2 5АУ " 

1194 @ 16,2 8АУ * 

1195 @ 17Д 5АѴ " 

1196 @ 18Д 8АѴ " 

1197 @ 19 Д 5АѴ 


Установи! (ШЛ5ЕIV 


Импорт 

Экспорт 


Копировать 


Удалить 


Переименовать 


Оглавление 


Память 


СОЬОК СК+/СІ+ 
"СОЪОК СК+/0 + 

■СОІХЖСК+/0+ 

•сюьокок+/о+ 

СОЪОК СК+/0 + 

•соъок ОК+/С+ 
"СОІХЖОК+/0 + 
"С01ХЖ0К+/0 + 
"С0Ъ0КСК+/0 + 

соъок ок+/о+ 
СОЪОК СК+/С + 
СОЪОК ОК+/С + 
, сошкок+/о+ 
• СОЪОК ОК+/С+ 
"СОЪОК СК+/С + 
СОЪОК СК+/С + 


1198 @ 4,27 5АУ "Установи! сШАЗЕ IV - устанавливает параметры и " 

1199 @ 5,27 8АУ" опции системы СІВА5Е IV 

1200 @6,27 5АУ " 

1201 @ 7,27 5АѴ "Экспорт - экспортирует файлы ЕД «1ВА5Е ГѴ в файлы " 

1202 @8,27 ЗЛУ" формата РР8, аВА8Е П, Ргатсагогк, КРО " 

1203 @9,27 5АУ" 

1204 @ 10,27 5ЛѴ "Импорт - импортирует файлы формата РР5, сШЛЗЕ II" 

1205 @ 11,27 2ІАУ " Ргатеѵогк, НРБ, ѴК1 в файл ЕД сІВАЗЕ IV а 

1206 @ 12Д7 8АУ " 

1207 @ 13,27 5АУ "Копировать/Удалять - копирует/удаляет файлы 

1208 @ 14,27 8АУ " 

1209 @ 15,27 5АѴ "Оглавление - переименовывает выбранный файл в " 

1210 @ 16,27 8АѴ " файл с указанным именем " 

1211 @ 17,27 8АУ " 

1212 @ 18,27 5АѴ "Память - вычисляет свободную память " 

1213 хх =ІИКЕѴ (0) 

1214 @4,2 5АУ ■ 


1215 @5Д 

1216 @ 6 Д 

1217 @ 7Д 

1218 @8.2 


8АУ " 
8АУ " 
8АУ " 
5АѴ 


Сопігоі Сепіег 


ЕЮв 


• соъок ск+/о+ 
- соъок ск+/о+ 

" СОІХЖ СК+/С+ 
" СОЪОК ОК+/С+ 
"ШШКОК+/0 + 


1219 @9,2 РПХ ТО 19,23 СОЪОК В/В 

1220 @ 4,27 8АУ "Сопігоі Сепіег - завершает работу программы 

1221 @ 5,27 8АУ ■ н передает управление «1ВА5Е IV " 

1222 @6,27 5АУ " 

1223 @ 7,27 5АУ " 

1224 @8,27 5АУТЮБ 

1225 @ 9 Д7 ХАѴ " 

1226 @ 10,27 СЪЕЛИ ТО 19,76 

1227 хя=ШКЕУ(0) 

1228 ОЕАСПѴАТЕ ЧѴІИЕЮѴ Неірасг 

1229 КЕШКИ 


- завершает работу программы 
и осуществляет выход в ЕЮ8 


Процедура ВеІІ предназначена для звуковой сигнализации о возникшей в ходе 
выполнения программы ошибке и вызывается из процедуры Раи$е. При запуске 
процедуры звучит мелодия, состоящая из трех звуков. Команда БЕТ ВЕІ.І- ТО 
устанавливает частоту и длительность звучания, а команда ?? СН&(7) инициирует звук. 

1253 РКОСЕШЖЕ Вей 

1254 5ЕТ ВЕЪЪ ТО 1000,1 

1255 7? СНК(7) 

1256 5ЕТ ВЕІХ ТО 1300,1 

1257 77 СНК(7) 

1258 5ЕГ ВЕІХ ТО 10003 

1259 ??СНК(7) 

1260 КЕШКИ 
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Научно-технический центр "Эрго" 


при издательстве "Радио и связь" выполняет работы по 
внедрению программно-технических комплексов в области 
издательской и полиграфической деятельности, созданию 
новых информационных технологий и автоматизированных 
рабочих мест в управленческой деятельности. 

Незаменимым средством для этого является пакет СУБД 
<ШАЗЕ IV, работающий как в индивидуальном, так и 
сетевом режимах. Настоящая книга служит руководством 
для овладения этим пакетом пользователями, не имеющими 
специальной подготовки. Книга полезна и опытным про¬ 
граммистам, работающим в среде <ША8Е. 

Все примеры из глав 2 и 5 записаны на дискете, которую 
можно заказать. На этой дискете также помещается элек¬ 
тронный справочник по командам и функциям языка 
іШАЗЕ IV. 

ВНИМАНИЕ! Пакет СІВА8Е IV в полном объеме с 
кириллицей не работает. Для исправления этого недостатка 
можно использовать русификатор. В продаже имеется такой 
русификатор для пакета СІВА8Е IV. 

Принимаются также заказы на поставку лицензионных 
пакетов (ША8ЕIV, Ргашеѵѵогк III и других продуктов фирмы 
АзЬіоп-ТаІе. 


Заказы на выполнение работ и поставку программных 
продуктов можно сделать по адресу: 

Москвд'ЮЮОО, Почтамт а/я 693, НТЦ”ЭРГО" 

Справки по телефону: 923-24-51 



